PluginProbe ʕ •ᴥ•ʔ
WooCommerce / 9.9.5
WooCommerce v9.9.5
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-db.php
woocommerce / includes / log-handlers Last commit date
class-wc-log-handler-db.php 1 year ago class-wc-log-handler-email.php 5 years ago class-wc-log-handler-file.php 2 years ago
class-wc-log-handler-db.php
219 lines
1 <?php
2 /**
3 * Class WC_Log_Handler_DB file.
4 *
5 * @package WooCommerce\Log Handlers
6 */
7
8 use Automattic\Jetpack\Constants;
9
10 if ( ! defined( 'ABSPATH' ) ) {
11 exit; // Exit if accessed directly.
12 }
13
14 /**
15 * Handles log entries by writing to database.
16 *
17 * @class WC_Log_Handler_DB
18 * @version 1.0.0
19 * @package WooCommerce\Classes\Log_Handlers
20 */
21 class WC_Log_Handler_DB extends WC_Log_Handler {
22
23 /**
24 * Handle a log entry.
25 *
26 * @param int $timestamp Log timestamp.
27 * @param string $level emergency|alert|critical|error|warning|notice|info|debug.
28 * @param string $message Log message.
29 * @param array $context {
30 * Additional information for log handlers.
31 *
32 * @type string $source Optional. Source will be available in log table.
33 * If no source is provided, attempt to provide sensible default.
34 * }
35 *
36 * @see WC_Log_Handler_DB::get_log_source() for default source.
37 *
38 * @return bool False if value was not handled and true if value was handled.
39 */
40 public function handle( $timestamp, $level, $message, $context ) {
41 if ( isset( $context['source'] ) && $context['source'] ) {
42 $source = $context['source'];
43 } else {
44 $source = $this->get_log_source();
45 }
46
47 // Clear the source cache if this is a new source.
48 $cached_sources = get_option( WC_Admin_Log_Table_List::SOURCE_CACHE_OPTION_KEY, array() );
49 if ( ! in_array( $source, $cached_sources, true ) ) {
50 delete_option( WC_Admin_Log_Table_List::SOURCE_CACHE_OPTION_KEY );
51 }
52
53 return $this->add( $timestamp, $level, $message, $source, $context );
54 }
55
56 /**
57 * Add a log entry to chosen file.
58 *
59 * @param int $timestamp Log timestamp.
60 * @param string $level emergency|alert|critical|error|warning|notice|info|debug.
61 * @param string $message Log message.
62 * @param string $source Log source. Useful for filtering and sorting.
63 * @param array $context Context will be serialized and stored in database.
64 *
65 * @return bool True if write was successful.
66 */
67 protected static function add( $timestamp, $level, $message, $source, $context ) {
68 global $wpdb;
69
70 $insert = array(
71 'timestamp' => date( 'Y-m-d H:i:s', $timestamp ),
72 'level' => WC_Log_Levels::get_level_severity( $level ),
73 'message' => $message,
74 'source' => $source,
75 );
76
77 $format = array(
78 '%s',
79 '%d',
80 '%s',
81 '%s',
82 '%s', // possible serialized context.
83 );
84
85 unset( $context['source'] );
86 if ( ! empty( $context ) ) {
87 if ( isset( $context['backtrace'] ) && true === filter_var( $context['backtrace'], FILTER_VALIDATE_BOOLEAN ) ) {
88 $context['backtrace'] = self::get_backtrace();
89 }
90
91 $insert['context'] = wp_json_encode( $context, JSON_PRETTY_PRINT );
92 }
93
94 return false !== $wpdb->insert( "{$wpdb->prefix}woocommerce_log", $insert, $format );
95 }
96
97 /**
98 * Clear all logs from the DB.
99 *
100 * @return bool True if flush was successful.
101 */
102 public static function flush() {
103 global $wpdb;
104
105 return $wpdb->query( "TRUNCATE TABLE {$wpdb->prefix}woocommerce_log" );
106 }
107
108 /**
109 * Clear entries for a chosen handle/source.
110 *
111 * @param string $source Log source.
112 * @return bool
113 */
114 public function clear( $source ) {
115 global $wpdb;
116
117 return $wpdb->query(
118 $wpdb->prepare(
119 "DELETE FROM {$wpdb->prefix}woocommerce_log WHERE source = %s",
120 $source
121 )
122 );
123 }
124
125 /**
126 * Delete selected logs from DB.
127 *
128 * @param int|string|array $log_ids Log ID or array of Log IDs to be deleted.
129 *
130 * @return bool
131 */
132 public static function delete( $log_ids ) {
133 global $wpdb;
134
135 if ( ! is_array( $log_ids ) ) {
136 $log_ids = array( $log_ids );
137 }
138
139 $format = array_fill( 0, count( $log_ids ), '%d' );
140 $query_in = '(' . implode( ',', $format ) . ')';
141
142 $result = $wpdb->query(
143 // phpcs:disable WordPress.DB.PreparedSQL.InterpolatedNotPrepared
144 $wpdb->prepare(
145 "
146 DELETE FROM {$wpdb->prefix}woocommerce_log
147 WHERE log_id IN {$query_in}
148 ",
149 $log_ids
150 )
151 // phpcs:enable WordPress.DB.PreparedSQL.InterpolatedNotPrepared
152 );
153
154 if ( false !== $result ) {
155 \WC_Cache_Helper::get_transient_version( 'logs-db', true );
156 }
157
158 return $result;
159 }
160
161 /**
162 * Delete all logs older than a defined timestamp.
163 *
164 * @since 3.4.0
165 * @param integer $timestamp Timestamp to delete logs before.
166 */
167 public static function delete_logs_before_timestamp( $timestamp = 0 ) {
168 if ( ! $timestamp ) {
169 return;
170 }
171
172 global $wpdb;
173
174 $wpdb->query(
175 $wpdb->prepare(
176 "DELETE FROM {$wpdb->prefix}woocommerce_log WHERE timestamp < %s",
177 date( 'Y-m-d H:i:s', $timestamp )
178 )
179 );
180
181 \WC_Cache_Helper::get_transient_version( 'logs-db', true );
182 }
183
184 /**
185 * Get appropriate source based on file name.
186 *
187 * Try to provide an appropriate source in case none is provided.
188 *
189 * @return string Text to use as log source. "" (empty string) if none is found.
190 */
191 protected static function get_log_source() {
192 static $ignore_files = array( 'class-wc-log-handler-db', 'class-wc-logger' );
193
194 /**
195 * PHP < 5.3.6 correct behavior
196 *
197 * @see http://php.net/manual/en/function.debug-backtrace.php#refsect1-function.debug-backtrace-parameters
198 */
199 if ( Constants::is_defined( 'DEBUG_BACKTRACE_IGNORE_ARGS' ) ) {
200 $debug_backtrace_arg = DEBUG_BACKTRACE_IGNORE_ARGS; // phpcs:ignore PHPCompatibility.Constants.NewConstants.debug_backtrace_ignore_argsFound
201 } else {
202 $debug_backtrace_arg = false;
203 }
204
205 $trace = debug_backtrace( $debug_backtrace_arg ); // @codingStandardsIgnoreLine.
206 foreach ( $trace as $t ) {
207 if ( isset( $t['file'] ) ) {
208 $filename = pathinfo( $t['file'], PATHINFO_FILENAME );
209 if ( ! in_array( $filename, $ignore_files, true ) ) {
210 return $filename;
211 }
212 }
213 }
214
215 return '';
216 }
217
218 }
219