PluginProbe ʕ •ᴥ•ʔ
WooCommerce / 6.1.1
WooCommerce v6.1.1
10.8.1 10.8.0 10.8.0-rc.1 10.8.0-beta.2 10.8.0-beta.1 7.8.0-beta.1 7.8.0-beta.2 7.8.0-rc.1 7.8.0-rc.2 7.8.1 7.8.2 7.8.3 7.8.4 7.9.0 7.9.0-beta.1 7.9.0-beta.2 7.9.0-rc.2 7.9.0-rc.3 7.9.1 7.9.2 8.0.0 8.0.0-beta.1 8.0.0-beta.2 8.0.0-rc.1 8.0.0-rc.2 8.0.1 8.0.2 8.0.3 8.0.4 8.0.5 8.1.0 8.1.0-beta.1 8.1.0-rc.1 8.1.0-rc.2 8.1.1 8.1.2 8.1.3 8.1.4 8.2.0 8.2.0-beta.1 8.2.0-rc.1 8.2.0-rc.2 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.3.0 8.3.0-beta.1 8.3.0-rc.1 8.3.0-rc.2 8.3.1 8.3.2 8.3.3 8.3.4 8.4.0 8.4.0-beta.1 8.4.0-rc.1 8.4.1 8.4.2 8.4.3 8.5.0 8.5.0-beta.1 8.5.0-rc.1 8.5.1 8.5.2 8.5.3 8.5.4 8.5.5 8.6.0 8.6.0-beta.1 8.6.0-rc.1 8.6.1 8.6.2 8.6.3 8.6.4 8.7.0 8.7.0-beta.1 8.7.0-beta.2 8.7.0-rc.1 8.7.1 8.7.2 8.7.3 8.8.0 8.8.0-beta.1 8.8.0-rc.1 8.8.1 8.8.2 8.8.3 8.8.4 8.8.5 8.8.6 8.8.7 8.9.0 8.9.0-beta.1 8.9.0-rc.1 8.9.1 8.9.2 8.9.3 8.9.4 8.9.5 9.0.0 9.0.0-beta.1 9.0.0-beta.2 9.0.0-rc.1 9.0.1 9.0.2 9.0.3 9.0.4 9.1.0 9.1.0-beta.1 9.1.0-rc.1 9.1.1 9.1.2 9.1.3 9.1.4 9.1.5 9.1.6 9.2.0 9.2.0-beta.1 9.2.0-rc.1 9.2.1 9.2.2 9.2.3 9.2.4 9.2.5 9.3.0 9.3.0-beta.1 9.3.0-rc.1 9.3.1 9.3.2 9.3.3 9.3.4 9.3.5 9.3.6 9.4.0 9.4.0-beta.1 9.4.0-beta.2 9.4.0-rc.1 9.4.0-rc.2 9.4.0-rc.3 9.4.0-rc.4 9.4.1 9.4.2 9.4.3 9.4.4 9.4.5 9.5.0 9.5.0-beta.1 9.5.0-beta.2 9.5.0-rc.1 9.5.1 9.5.2 9.5.3 9.5.4 9.6.0 9.6.0-beta.1 9.6.0-beta.2 9.6.0-rc.1 9.6.1 9.6.2 9.6.3 9.6.4 9.7.0 9.7.0-beta.1 9.7.0-rc.1 9.7.1 9.7.2 9.7.3 9.8.0 9.8.0-beta.1 9.8.0-rc.1 9.8.1 9.8.2 9.8.3 9.8.4 9.8.5 9.8.6 9.8.7 9.9.0 9.9.0-beta.1 9.9.0-rc.1 9.9.1 9.9.2 9.9.3 9.9.4 9.9.5 9.9.6 9.9.7 3.7.3 7.1.2 3.8.0 7.2.0 3.8.0-beta.1 7.2.0-beta.1 3.8.0-rc.1 7.2.0-beta.2 3.8.0-rc.2 7.2.0-rc.1 3.8.1 7.2.0-rc.2 3.8.2 7.2.1 3.8.3 7.2.2 3.9.0 7.2.3 3.9.0-beta.1 7.2.4 3.9.0-beta.2 7.3.0 3.9.0-rc.1 7.3.0-beta.1 3.9.0-rc.2 7.3.0-beta.2 3.9.0-rc.3 7.3.0-rc.1 3.9.0-rc.4 7.3.0-rc.2 3.9.1 7.3.1 3.9.2 7.4.0 3.9.3 7.4.0-beta.1 3.9.4 7.4.0-beta.2 3.9.5 7.4.0-rc.1 4.0.0 7.4.0-rc.2 4.0.0-beta.1 7.4.1 4.0.0-rc.1 7.4.2 4.0.0-rc.2 7.5.0 4.0.1 7.5.0-beta.1 4.0.2 7.5.0-beta.2 4.0.3 7.5.0-rc.1 4.0.4 7.5.1 4.1.0 7.5.2 4.1.0-beta.1 7.6.0 4.1.0-beta.2 7.6.0-beta.1 4.1.0-rc.1 7.6.0-beta.2 4.1.0-rc.2 7.6.0-rc.1 4.1.1 7.6.0-rc.2 4.1.2 7.6.0-rc.3 4.1.3 7.6.1 4.1.4 7.6.2 4.2.0 7.7.0 4.2.0-RC.1 7.7.0-beta.1 4.2.0-RC.2 7.7.0-beta.2 4.2.0-beta.1 7.7.0-rc.1 4.2.1 7.7.1 4.2.2 7.7.2 4.2.3 7.7.3 4.2.4 7.8.0 4.2.5 4.3.0 4.3.0-beta.1 4.3.0-rc.1 4.3.0-rc.2 4.3.0-rc.3 4.3.1 4.3.2 4.3.3 4.3.4 4.3.5 4.3.6 4.4.0 4.4.0-beta.1 4.4.0-rc.1 4.4.1 4.4.2 4.4.3 4.4.4 4.5.0 4.5.0-beta.1 4.5.0-rc.1 4.5.0-rc.3 4.5.1 4.5.2 4.5.3 4.5.4 4.5.5 4.6.0 4.6.0-beta.1 4.6.0-rc.1 4.6.1 4.6.2 4.6.3 4.6.4 4.6.5 4.7.0 4.7.0-beta.1 4.7.0-beta.2 4.7.0-rc.1 4.7.1 4.7.1-beta.1 4.7.2 4.7.3 4.7.4 4.8.0 4.8.0-beta.1 4.8.0-rc.1 4.8.0-rc.2 4.8.1 4.8.2 4.8.3 4.9.0 4.9.0-beta.1 4.9.0-rc.1 4.9.0-rc.2 4.9.1 4.9.2 4.9.3 4.9.4 4.9.5 5.0.0 5.0.0-beta.1 5.0.0-beta.2 5.0.0-rc.1 5.0.0-rc.2 5.0.0-rc.3 5.0.1 5.0.2 5.0.3 5.1.0 5.1.0-beta.1 5.1.0-rc.1 trunk 5.1.1 10.0.0 5.1.2 10.0.0-rc.1 5.1.3 10.0.0-rc.2 5.2.0 10.0.1 5.2.0-beta.1 10.0.2 5.2.0-rc.1 10.0.3 5.2.0-rc.2 10.0.4 5.2.1 10.0.5 5.2.2 10.0.6 5.2.3 10.1.0 5.2.4 10.1.0-rc.1 5.2.5 10.1.0-rc.2 5.3.0 10.1.0-rc.3 5.3.0-beta.1 10.1.0-rc.4 5.3.0-rc.1 10.1.1 5.3.0-rc.2 10.1.2 5.3.1 10.1.3 5.3.2 10.1.4 5.3.3 10.2.0 5.4.0 10.2.0-beta.1 5.4.0-beta.1 10.2.0-beta.2 5.4.0-rc.1 10.2.0-rc.1 5.4.1 10.2.1 5.4.2 10.2.2 5.4.3 10.2.3 5.4.4 10.2.4 5.4.5 10.3.0 5.5.0 10.3.0-beta.1 5.5.0-beta.1 10.3.0-beta.2 5.5.0-rc.1 10.3.0-rc.1 5.5.0-rc.2 10.3.0-rc.2 5.5.1 10.3.1 5.5.2 10.3.2 5.5.3 10.3.3 5.5.4 10.3.4 5.5.5 10.3.5 5.6.0 10.3.6 5.6.0-beta.1 10.3.7 5.6.0-rc.1 10.3.8 5.6.0-rc.2 10.4.0 5.6.1 10.4.0-beta.1 5.6.2 10.4.0-beta.2 5.6.3 10.4.0-rc.1 5.7.0 10.4.1 5.7.0-beta.1 10.4.2 5.7.0-rc.1 10.4.3 5.7.1 10.4.4 5.7.2 10.5.0 5.7.3 10.5.0-beta.1 5.8.0 10.5.0-beta.2 5.8.0-beta.1 10.5.0-rc.1 5.8.0-beta.2 10.5.0-rc.2 5.8.0-rc.1 10.5.0-rc.3 5.8.1 10.5.1 5.8.2 10.5.2 5.9.0 10.5.3 5.9.0-beta.1 10.6.0 5.9.0-rc.1 10.6.0-beta.1 5.9.0-rc.2 10.6.0-beta.2 5.9.1 10.6.0-rc.1 5.9.2 10.6.1 6.0.0 10.6.2 6.0.0-beta.1 10.7.0 6.0.0-rc.1 10.7.0-beta.1 6.0.1 10.7.0-beta.2 6.0.2 10.7.0-rc.1 6.1.0 3.0.0 6.1.0-beta.1 3.0.1 6.1.0-rc.1 3.0.2 6.1.0-rc.2 3.0.3 6.1.1 3.0.4 6.1.2 3.0.5 6.1.3 3.0.6 6.2.0 3.0.7 6.2.0-beta.1 3.0.8 6.2.0-rc.1 3.0.9 6.2.0-rc.2 3.1.0 6.2.1 3.1.1 6.2.2 3.1.2 6.2.3 3.2.0 6.3.0 3.2.1 6.3.0-beta.1 3.2.2 6.3.0-rc.1 3.2.3 6.3.0-rc.2 3.2.4 6.3.1 3.2.5 6.3.2 3.2.6 6.4.0 3.3.0 6.4.0-beta.1 3.3.1 6.4.0-rc.1 3.3.2 6.4.1 3.3.2-rc.1 6.4.2 3.3.3 6.5.0 3.3.4 6.5.0-beta.1 3.3.5 6.5.0-rc.1 3.3.6 6.5.0-rc.2 3.4.0 6.5.1 3.4.0-beta.1 6.5.2 3.4.0-rc.2 6.6.0 3.4.1 6.6.0-beta.1 3.4.2 6.6.0-rc.1 3.4.3 6.6.0-rc.2 3.4.4 6.6.1 3.4.5 6.6.2 3.4.6 6.7.0 3.4.7 6.7.0-beta.1 3.4.8 6.7.0-beta.2 3.5.0 6.7.0-rc.1 3.5.0-beta.1 6.7.1 3.5.0-rc.1 6.8.0 3.5.0-rc.2 6.8.0-beta.1 3.5.1 6.8.0-beta.2 3.5.10 6.8.0-rc.1 3.5.2 6.8.1 3.5.3 6.8.2 3.5.4 6.8.3 3.5.5 6.9.0 3.5.6 6.9.0-beta.1 3.5.7 6.9.0-beta.2 3.5.8 6.9.0-rc.1 3.5.9 6.9.1 3.6.0 6.9.2 3.6.0-beta.1 6.9.3 3.6.0-rc.1 6.9.4 3.6.0-rc.2 6.9.5 3.6.0-rc.3 7.0.0 3.6.1 7.0.0-beta.1 3.6.2 7.0.0-beta.2 3.6.3 7.0.0-beta.3 3.6.4 7.0.0-rc.1 3.6.5 7.0.0-rc.2 3.6.6 7.0.1 3.6.7 7.0.2 3.7.0 7.1.0 3.7.0-beta.1 7.1.0-beta.1 3.7.0-rc.1 7.1.0-beta.2 3.7.0-rc.2 7.1.0-rc.1 3.7.1 7.1.0-rc.2 3.7.2 7.1.1
woocommerce / includes / log-handlers / class-wc-log-handler-email.php
woocommerce / includes / log-handlers Last commit date
class-wc-log-handler-db.php 5 years ago class-wc-log-handler-email.php 5 years ago class-wc-log-handler-file.php 5 years ago
class-wc-log-handler-email.php
227 lines
1 <?php
2 /**
3 * Class WC_Log_Handler_Email file.
4 *
5 * @package WooCommerce\Log Handlers
6 */
7
8 if ( ! defined( 'ABSPATH' ) ) {
9 exit; // Exit if accessed directly.
10 }
11
12 /**
13 * Handles log entries by sending an email.
14 *
15 * WARNING!
16 * This log handler has known limitations.
17 *
18 * Log messages are aggregated and sent once per request (if necessary). If the site experiences a
19 * problem, the log email may never be sent. This handler should be used with another handler which
20 * stores logs in order to prevent loss.
21 *
22 * It is not recommended to use this handler on a high traffic site. There will be a maximum of 1
23 * email sent per request per handler, but that could still be a dangerous amount of emails under
24 * heavy traffic. Do not confuse this handler with an appropriate monitoring solution!
25 *
26 * If you understand these limitations, feel free to use this handler or borrow parts of the design
27 * to implement your own!
28 *
29 * @class WC_Log_Handler_Email
30 * @version 1.0.0
31 * @package WooCommerce\Classes\Log_Handlers
32 */
33 class WC_Log_Handler_Email extends WC_Log_Handler {
34
35 /**
36 * Minimum log level this handler will process.
37 *
38 * @var int Integer representation of minimum log level to handle.
39 */
40 protected $threshold;
41
42 /**
43 * Stores email recipients.
44 *
45 * @var array
46 */
47 protected $recipients = array();
48
49 /**
50 * Stores log messages.
51 *
52 * @var array
53 */
54 protected $logs = array();
55
56 /**
57 * Stores integer representation of maximum logged level.
58 *
59 * @var int
60 */
61 protected $max_severity = null;
62
63 /**
64 * Constructor for log handler.
65 *
66 * @param string|array $recipients Optional. Email(s) to receive log messages. Defaults to site admin email.
67 * @param string $threshold Optional. Minimum level that should receive log messages.
68 * Default 'alert'. One of: emergency|alert|critical|error|warning|notice|info|debug.
69 */
70 public function __construct( $recipients = null, $threshold = 'alert' ) {
71 if ( null === $recipients ) {
72 $recipients = get_option( 'admin_email' );
73 }
74
75 if ( is_array( $recipients ) ) {
76 foreach ( $recipients as $recipient ) {
77 $this->add_email( $recipient );
78 }
79 } else {
80 $this->add_email( $recipients );
81 }
82
83 $this->set_threshold( $threshold );
84 add_action( 'shutdown', array( $this, 'send_log_email' ) );
85 }
86
87 /**
88 * Set handler severity threshold.
89 *
90 * @param string $level emergency|alert|critical|error|warning|notice|info|debug.
91 */
92 public function set_threshold( $level ) {
93 $this->threshold = WC_Log_Levels::get_level_severity( $level );
94 }
95
96 /**
97 * Determine whether handler should handle log.
98 *
99 * @param string $level emergency|alert|critical|error|warning|notice|info|debug.
100 * @return bool True if the log should be handled.
101 */
102 protected function should_handle( $level ) {
103 return $this->threshold <= WC_Log_Levels::get_level_severity( $level );
104 }
105
106 /**
107 * Handle a log entry.
108 *
109 * @param int $timestamp Log timestamp.
110 * @param string $level emergency|alert|critical|error|warning|notice|info|debug.
111 * @param string $message Log message.
112 * @param array $context Optional. Additional information for log handlers.
113 *
114 * @return bool False if value was not handled and true if value was handled.
115 */
116 public function handle( $timestamp, $level, $message, $context ) {
117
118 if ( $this->should_handle( $level ) ) {
119 $this->add_log( $timestamp, $level, $message, $context );
120 return true;
121 }
122
123 return false;
124 }
125
126 /**
127 * Send log email.
128 *
129 * @return bool True if email is successfully sent otherwise false.
130 */
131 public function send_log_email() {
132 $result = false;
133
134 if ( ! empty( $this->logs ) ) {
135 $subject = $this->get_subject();
136 $body = $this->get_body();
137 $result = wp_mail( $this->recipients, $subject, $body );
138 $this->clear_logs();
139 }
140
141 return $result;
142 }
143
144 /**
145 * Build subject for log email.
146 *
147 * @return string subject
148 */
149 protected function get_subject() {
150 $site_name = get_bloginfo( 'name' );
151 $max_level = strtoupper( WC_Log_Levels::get_severity_level( $this->max_severity ) );
152 $log_count = count( $this->logs );
153
154 return sprintf(
155 /* translators: 1: Site name 2: Maximum level 3: Log count */
156 _n(
157 '[%1$s] %2$s: %3$s WooCommerce log message',
158 '[%1$s] %2$s: %3$s WooCommerce log messages',
159 $log_count,
160 'woocommerce'
161 ),
162 $site_name,
163 $max_level,
164 $log_count
165 );
166 }
167
168 /**
169 * Build body for log email.
170 *
171 * @return string body
172 */
173 protected function get_body() {
174 $site_name = get_bloginfo( 'name' );
175 $entries = implode( PHP_EOL, $this->logs );
176 $log_count = count( $this->logs );
177 return _n(
178 'You have received the following WooCommerce log message:',
179 'You have received the following WooCommerce log messages:',
180 $log_count,
181 'woocommerce'
182 ) . PHP_EOL
183 . PHP_EOL
184 . $entries
185 . PHP_EOL
186 . PHP_EOL
187 /* translators: %s: Site name */
188 . sprintf( __( 'Visit %s admin area:', 'woocommerce' ), $site_name )
189 . PHP_EOL
190 . admin_url();
191 }
192
193 /**
194 * Adds an email to the list of recipients.
195 *
196 * @param string $email Email address to add.
197 */
198 public function add_email( $email ) {
199 array_push( $this->recipients, $email );
200 }
201
202 /**
203 * Add log message.
204 *
205 * @param int $timestamp Log timestamp.
206 * @param string $level emergency|alert|critical|error|warning|notice|info|debug.
207 * @param string $message Log message.
208 * @param array $context Additional information for log handlers.
209 */
210 protected function add_log( $timestamp, $level, $message, $context ) {
211 $this->logs[] = $this->format_entry( $timestamp, $level, $message, $context );
212
213 $log_severity = WC_Log_Levels::get_level_severity( $level );
214 if ( $this->max_severity < $log_severity ) {
215 $this->max_severity = $log_severity;
216 }
217 }
218
219 /**
220 * Clear log messages.
221 */
222 protected function clear_logs() {
223 $this->logs = array();
224 }
225
226 }
227