PluginProbe ʕ •ᴥ•ʔ
WooCommerce / 4.1.0-rc.2
WooCommerce v4.1.0-rc.2
10.9.1 10.9.0 10.9.0-rc.1 10.9.0-beta.2 10.9.0-beta.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 / data-stores / class-wc-customer-download-log-data-store.php
woocommerce / includes / data-stores Last commit date
abstract-wc-order-data-store-cpt.php 6 years ago abstract-wc-order-item-type-data-store.php 6 years ago class-wc-coupon-data-store-cpt.php 6 years ago class-wc-customer-data-store-session.php 7 years ago class-wc-customer-data-store.php 6 years ago class-wc-customer-download-data-store.php 6 years ago class-wc-customer-download-log-data-store.php 6 years ago class-wc-data-store-wp.php 6 years ago class-wc-order-data-store-cpt.php 6 years ago class-wc-order-item-coupon-data-store.php 8 years ago class-wc-order-item-data-store.php 6 years ago class-wc-order-item-fee-data-store.php 8 years ago class-wc-order-item-product-data-store.php 8 years ago class-wc-order-item-shipping-data-store.php 8 years ago class-wc-order-item-tax-data-store.php 6 years ago class-wc-order-refund-data-store-cpt.php 6 years ago class-wc-payment-token-data-store.php 6 years ago class-wc-product-data-store-cpt.php 6 years ago class-wc-product-grouped-data-store-cpt.php 7 years ago class-wc-product-variable-data-store-cpt.php 6 years ago class-wc-product-variation-data-store-cpt.php 6 years ago class-wc-shipping-zone-data-store.php 6 years ago class-wc-webhook-data-store.php 6 years ago
class-wc-customer-download-log-data-store.php
240 lines
1 <?php
2 /**
3 * Class WC_Customer_Download_Log_Data_Store file.
4 *
5 * @version 3.3.0
6 * @package WooCommerce\Classes
7 */
8
9 defined( 'ABSPATH' ) || exit;
10
11 /**
12 * WC_Customer_Download_Log_Data_Store class.
13 */
14 class WC_Customer_Download_Log_Data_Store implements WC_Customer_Download_Log_Data_Store_Interface {
15
16 // Table name for download logs.
17 const WC_DOWNLOAD_LOG_TABLE = 'wc_download_log';
18
19 /**
20 * Get the table name for download logs.
21 *
22 * @return string
23 */
24 public static function get_table_name() {
25 return self::WC_DOWNLOAD_LOG_TABLE;
26 }
27
28 /**
29 * Create download log entry.
30 *
31 * @param WC_Customer_Download_Log $download_log Customer download log object.
32 */
33 public function create( WC_Customer_Download_Log &$download_log ) {
34 global $wpdb;
35
36 // Always set a timestamp.
37 if ( is_null( $download_log->get_timestamp( 'edit' ) ) ) {
38 $download_log->set_timestamp( time() );
39 }
40
41 $data = array(
42 'timestamp' => date( 'Y-m-d H:i:s', $download_log->get_timestamp( 'edit' )->getTimestamp() ),
43 'permission_id' => $download_log->get_permission_id( 'edit' ),
44 'user_id' => $download_log->get_user_id( 'edit' ),
45 'user_ip_address' => $download_log->get_user_ip_address( 'edit' ),
46 );
47
48 $format = array(
49 '%s',
50 '%s',
51 '%s',
52 '%s',
53 );
54
55 $result = $wpdb->insert(
56 $wpdb->prefix . self::get_table_name(),
57 apply_filters( 'woocommerce_downloadable_product_download_log_insert_data', $data ),
58 apply_filters( 'woocommerce_downloadable_product_download_log_insert_format', $format, $data )
59 );
60
61 do_action( 'woocommerce_downloadable_product_download_log_insert', $data );
62
63 if ( $result ) {
64 $download_log->set_id( $wpdb->insert_id );
65 $download_log->apply_changes();
66 } else {
67 wp_die( esc_html__( 'Unable to insert download log entry in database.', 'woocommerce' ) );
68 }
69 }
70
71 /**
72 * Method to read a download log from the database.
73 *
74 * @param WC_Customer_Download_Log $download_log Download log object.
75 * @throws Exception Exception when read is not possible.
76 */
77 public function read( &$download_log ) {
78 global $wpdb;
79
80 $download_log->set_defaults();
81
82 // Ensure we have an id to pull from the DB.
83 if ( ! $download_log->get_id() ) {
84 throw new Exception( __( 'Invalid download log: no ID.', 'woocommerce' ) );
85 }
86
87 $table = $wpdb->prefix . self::get_table_name();
88
89 // Query the DB for the download log.
90 $raw_download_log = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM {$table} WHERE download_log_id = %d", $download_log->get_id() ) ); // WPCS: unprepared SQL ok.
91
92 if ( ! $raw_download_log ) {
93 throw new Exception( __( 'Invalid download log: not found.', 'woocommerce' ) );
94 }
95
96 $download_log->set_props(
97 array(
98 'timestamp' => strtotime( $raw_download_log->timestamp ),
99 'permission_id' => $raw_download_log->permission_id,
100 'user_id' => $raw_download_log->user_id,
101 'user_ip_address' => $raw_download_log->user_ip_address,
102 )
103 );
104
105 $download_log->set_object_read( true );
106 }
107
108 /**
109 * Method to update a download log in the database.
110 *
111 * @param WC_Customer_Download_Log $download_log Download log object.
112 */
113 public function update( &$download_log ) {
114 global $wpdb;
115
116 $data = array(
117 'timestamp' => date( 'Y-m-d H:i:s', $download_log->get_timestamp( 'edit' )->getTimestamp() ),
118 'permission_id' => $download_log->get_permission_id( 'edit' ),
119 'user_id' => $download_log->get_user_id( 'edit' ),
120 'user_ip_address' => $download_log->get_user_ip_address( 'edit' ),
121 );
122
123 $format = array(
124 '%s',
125 '%s',
126 '%s',
127 '%s',
128 );
129
130 $wpdb->update(
131 $wpdb->prefix . self::get_table_name(),
132 $data,
133 array(
134 'download_log_id' => $download_log->get_id(),
135 ),
136 $format
137 );
138 $download_log->apply_changes();
139 }
140
141 /**
142 * Get a download log object.
143 *
144 * @param array $data From the DB.
145 * @return WC_Customer_Download_Log
146 */
147 private function get_download_log( $data ) {
148 return new WC_Customer_Download_Log( $data );
149 }
150
151 /**
152 * Get array of download log ids by specified args.
153 *
154 * @param array $args Arguments to define download logs to retrieve.
155 * @return array
156 */
157 public function get_download_logs( $args = array() ) {
158 global $wpdb;
159
160 $args = wp_parse_args(
161 $args,
162 array(
163 'permission_id' => '',
164 'user_id' => '',
165 'user_ip_address' => '',
166 'orderby' => 'download_log_id',
167 'order' => 'ASC',
168 'limit' => -1,
169 'page' => 1,
170 'return' => 'objects',
171 )
172 );
173
174 $query = array();
175 $table = $wpdb->prefix . self::get_table_name();
176 $query[] = "SELECT * FROM {$table} WHERE 1=1";
177
178 if ( $args['permission_id'] ) {
179 $query[] = $wpdb->prepare( 'AND permission_id = %d', $args['permission_id'] );
180 }
181
182 if ( $args['user_id'] ) {
183 $query[] = $wpdb->prepare( 'AND user_id = %d', $args['user_id'] );
184 }
185
186 if ( $args['user_ip_address'] ) {
187 $query[] = $wpdb->prepare( 'AND user_ip_address = %s', $args['user_ip_address'] );
188 }
189
190 $allowed_orders = array( 'download_log_id', 'timestamp', 'permission_id', 'user_id' );
191 $orderby = in_array( $args['orderby'], $allowed_orders, true ) ? $args['orderby'] : 'download_log_id';
192 $order = 'DESC' === strtoupper( $args['order'] ) ? 'DESC' : 'ASC';
193 $orderby_sql = sanitize_sql_orderby( "{$orderby} {$order}" );
194 $query[] = "ORDER BY {$orderby_sql}";
195
196 if ( 0 < $args['limit'] ) {
197 $query[] = $wpdb->prepare( 'LIMIT %d, %d', absint( $args['limit'] ) * absint( $args['page'] - 1 ), absint( $args['limit'] ) );
198 }
199
200 $raw_download_logs = $wpdb->get_results( implode( ' ', $query ) ); // WPCS: unprepared SQL ok.
201
202 switch ( $args['return'] ) {
203 case 'ids':
204 return wp_list_pluck( $raw_download_logs, 'download_log_id' );
205 default:
206 return array_map( array( $this, 'get_download_log' ), $raw_download_logs );
207 }
208 }
209
210 /**
211 * Get download logs for a given download permission.
212 *
213 * @param int $permission_id Permission to get logs for.
214 * @return array
215 */
216 public function get_download_logs_for_permission( $permission_id ) {
217 // If no permission_id is passed, return an empty array.
218 if ( empty( $permission_id ) ) {
219 return array();
220 }
221
222 return $this->get_download_logs(
223 array(
224 'permission_id' => $permission_id,
225 )
226 );
227 }
228
229 /**
230 * Method to delete download logs for a given permission ID.
231 *
232 * @since 3.4.0
233 * @param int $id download_id of the downloads that will be deleted.
234 */
235 public function delete_by_permission_id( $id ) {
236 global $wpdb;
237 $wpdb->query( $wpdb->prepare( "DELETE FROM {$wpdb->prefix}woocommerce_downloadable_product_permissions WHERE permission_id = %d", $id ) );
238 }
239 }
240