Açıklama Yok

class-wc-privacy-exporters.php 15KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445
  1. <?php
  2. /**
  3. * Personal data exporters.
  4. *
  5. * @since 3.4.0
  6. * @package WooCommerce\Classes
  7. */
  8. defined( 'ABSPATH' ) || exit;
  9. /**
  10. * WC_Privacy_Exporters Class.
  11. */
  12. class WC_Privacy_Exporters {
  13. /**
  14. * Finds and exports customer data by email address.
  15. *
  16. * @since 3.4.0
  17. * @param string $email_address The user email address.
  18. * @return array An array of personal data in name value pairs
  19. */
  20. public static function customer_data_exporter( $email_address ) {
  21. $user = get_user_by( 'email', $email_address ); // Check if user has an ID in the DB to load stored personal data.
  22. $data_to_export = array();
  23. if ( $user instanceof WP_User ) {
  24. $customer_personal_data = self::get_customer_personal_data( $user );
  25. if ( ! empty( $customer_personal_data ) ) {
  26. $data_to_export[] = array(
  27. 'group_id' => 'woocommerce_customer',
  28. 'group_label' => __( 'Customer Data', 'woocommerce' ),
  29. 'group_description' => __( 'User&#8217;s WooCommerce customer data.', 'woocommerce' ),
  30. 'item_id' => 'user',
  31. 'data' => $customer_personal_data,
  32. );
  33. }
  34. }
  35. return array(
  36. 'data' => $data_to_export,
  37. 'done' => true,
  38. );
  39. }
  40. /**
  41. * Finds and exports data which could be used to identify a person from WooCommerce data associated with an email address.
  42. *
  43. * Orders are exported in blocks of 10 to avoid timeouts.
  44. *
  45. * @since 3.4.0
  46. * @param string $email_address The user email address.
  47. * @param int $page Page.
  48. * @return array An array of personal data in name value pairs
  49. */
  50. public static function order_data_exporter( $email_address, $page ) {
  51. $done = true;
  52. $page = (int) $page;
  53. $user = get_user_by( 'email', $email_address ); // Check if user has an ID in the DB to load stored personal data.
  54. $data_to_export = array();
  55. $order_query = array(
  56. 'limit' => 10,
  57. 'page' => $page,
  58. 'customer' => array( $email_address ),
  59. );
  60. if ( $user instanceof WP_User ) {
  61. $order_query['customer'][] = (int) $user->ID;
  62. }
  63. $orders = wc_get_orders( $order_query );
  64. if ( 0 < count( $orders ) ) {
  65. foreach ( $orders as $order ) {
  66. $data_to_export[] = array(
  67. 'group_id' => 'woocommerce_orders',
  68. 'group_label' => __( 'Orders', 'woocommerce' ),
  69. 'group_description' => __( 'User&#8217;s WooCommerce orders data.', 'woocommerce' ),
  70. 'item_id' => 'order-' . $order->get_id(),
  71. 'data' => self::get_order_personal_data( $order ),
  72. );
  73. }
  74. $done = 10 > count( $orders );
  75. }
  76. return array(
  77. 'data' => $data_to_export,
  78. 'done' => $done,
  79. );
  80. }
  81. /**
  82. * Finds and exports customer download logs by email address.
  83. *
  84. * @since 3.4.0
  85. * @param string $email_address The user email address.
  86. * @param int $page Page.
  87. * @throws Exception When WC_Data_Store validation fails.
  88. * @return array An array of personal data in name value pairs
  89. */
  90. public static function download_data_exporter( $email_address, $page ) {
  91. $done = true;
  92. $page = (int) $page;
  93. $user = get_user_by( 'email', $email_address ); // Check if user has an ID in the DB to load stored personal data.
  94. $data_to_export = array();
  95. $downloads_query = array(
  96. 'limit' => 10,
  97. 'page' => $page,
  98. );
  99. if ( $user instanceof WP_User ) {
  100. $downloads_query['user_id'] = (int) $user->ID;
  101. } else {
  102. $downloads_query['user_email'] = $email_address;
  103. }
  104. $customer_download_data_store = WC_Data_Store::load( 'customer-download' );
  105. $customer_download_log_data_store = WC_Data_Store::load( 'customer-download-log' );
  106. $downloads = $customer_download_data_store->get_downloads( $downloads_query );
  107. if ( 0 < count( $downloads ) ) {
  108. foreach ( $downloads as $download ) {
  109. $data_to_export[] = array(
  110. 'group_id' => 'woocommerce_downloads',
  111. /* translators: This is the headline for a list of downloads purchased from the store for a given user. */
  112. 'group_label' => __( 'Purchased Downloads', 'woocommerce' ),
  113. 'group_description' => __( 'User&#8217;s WooCommerce purchased downloads data.', 'woocommerce' ),
  114. 'item_id' => 'download-' . $download->get_id(),
  115. 'data' => self::get_download_personal_data( $download ),
  116. );
  117. $download_logs = $customer_download_log_data_store->get_download_logs_for_permission( $download->get_id() );
  118. foreach ( $download_logs as $download_log ) {
  119. $data_to_export[] = array(
  120. 'group_id' => 'woocommerce_download_logs',
  121. /* translators: This is the headline for a list of access logs for downloads purchased from the store for a given user. */
  122. 'group_label' => __( 'Access to Purchased Downloads', 'woocommerce' ),
  123. 'group_description' => __( 'User&#8217;s WooCommerce access to purchased downloads data.', 'woocommerce' ),
  124. 'item_id' => 'download-log-' . $download_log->get_id(),
  125. 'data' => array(
  126. array(
  127. 'name' => __( 'Download ID', 'woocommerce' ),
  128. 'value' => $download_log->get_permission_id(),
  129. ),
  130. array(
  131. 'name' => __( 'Timestamp', 'woocommerce' ),
  132. 'value' => $download_log->get_timestamp(),
  133. ),
  134. array(
  135. 'name' => __( 'IP Address', 'woocommerce' ),
  136. 'value' => $download_log->get_user_ip_address(),
  137. ),
  138. ),
  139. );
  140. }
  141. }
  142. $done = 10 > count( $downloads );
  143. }
  144. return array(
  145. 'data' => $data_to_export,
  146. 'done' => $done,
  147. );
  148. }
  149. /**
  150. * Get personal data (key/value pairs) for a user object.
  151. *
  152. * @since 3.4.0
  153. * @param WP_User $user user object.
  154. * @throws Exception If customer cannot be read/found and $data is set to WC_Customer class.
  155. * @return array
  156. */
  157. protected static function get_customer_personal_data( $user ) {
  158. $personal_data = array();
  159. $customer = new WC_Customer( $user->ID );
  160. if ( ! $customer ) {
  161. return array();
  162. }
  163. $props_to_export = apply_filters(
  164. 'woocommerce_privacy_export_customer_personal_data_props',
  165. array(
  166. 'billing_first_name' => __( 'Billing First Name', 'woocommerce' ),
  167. 'billing_last_name' => __( 'Billing Last Name', 'woocommerce' ),
  168. 'billing_company' => __( 'Billing Company', 'woocommerce' ),
  169. 'billing_address_1' => __( 'Billing Address 1', 'woocommerce' ),
  170. 'billing_address_2' => __( 'Billing Address 2', 'woocommerce' ),
  171. 'billing_city' => __( 'Billing City', 'woocommerce' ),
  172. 'billing_postcode' => __( 'Billing Postal/Zip Code', 'woocommerce' ),
  173. 'billing_state' => __( 'Billing State', 'woocommerce' ),
  174. 'billing_country' => __( 'Billing Country / Region', 'woocommerce' ),
  175. 'billing_phone' => __( 'Billing Phone Number', 'woocommerce' ),
  176. 'billing_email' => __( 'Email Address', 'woocommerce' ),
  177. 'shipping_first_name' => __( 'Shipping First Name', 'woocommerce' ),
  178. 'shipping_last_name' => __( 'Shipping Last Name', 'woocommerce' ),
  179. 'shipping_company' => __( 'Shipping Company', 'woocommerce' ),
  180. 'shipping_address_1' => __( 'Shipping Address 1', 'woocommerce' ),
  181. 'shipping_address_2' => __( 'Shipping Address 2', 'woocommerce' ),
  182. 'shipping_city' => __( 'Shipping City', 'woocommerce' ),
  183. 'shipping_postcode' => __( 'Shipping Postal/Zip Code', 'woocommerce' ),
  184. 'shipping_state' => __( 'Shipping State', 'woocommerce' ),
  185. 'shipping_country' => __( 'Shipping Country / Region', 'woocommerce' ),
  186. 'shipping_phone' => __( 'Shipping Phone Number', 'woocommerce' ),
  187. ),
  188. $customer
  189. );
  190. foreach ( $props_to_export as $prop => $description ) {
  191. $value = '';
  192. if ( is_callable( array( $customer, 'get_' . $prop ) ) ) {
  193. $value = $customer->{"get_$prop"}( 'edit' );
  194. }
  195. $value = apply_filters( 'woocommerce_privacy_export_customer_personal_data_prop_value', $value, $prop, $customer );
  196. if ( $value ) {
  197. $personal_data[] = array(
  198. 'name' => $description,
  199. 'value' => $value,
  200. );
  201. }
  202. }
  203. /**
  204. * Allow extensions to register their own personal data for this customer for the export.
  205. *
  206. * @since 3.4.0
  207. * @param array $personal_data Array of name value pairs.
  208. * @param WC_Order $order A customer object.
  209. */
  210. $personal_data = apply_filters( 'woocommerce_privacy_export_customer_personal_data', $personal_data, $customer );
  211. return $personal_data;
  212. }
  213. /**
  214. * Get personal data (key/value pairs) for an order object.
  215. *
  216. * @since 3.4.0
  217. * @param WC_Order $order Order object.
  218. * @return array
  219. */
  220. protected static function get_order_personal_data( $order ) {
  221. $personal_data = array();
  222. $props_to_export = apply_filters(
  223. 'woocommerce_privacy_export_order_personal_data_props',
  224. array(
  225. 'order_number' => __( 'Order Number', 'woocommerce' ),
  226. 'date_created' => __( 'Order Date', 'woocommerce' ),
  227. 'total' => __( 'Order Total', 'woocommerce' ),
  228. 'items' => __( 'Items Purchased', 'woocommerce' ),
  229. 'customer_ip_address' => __( 'IP Address', 'woocommerce' ),
  230. 'customer_user_agent' => __( 'Browser User Agent', 'woocommerce' ),
  231. 'formatted_billing_address' => __( 'Billing Address', 'woocommerce' ),
  232. 'formatted_shipping_address' => __( 'Shipping Address', 'woocommerce' ),
  233. 'billing_phone' => __( 'Phone Number', 'woocommerce' ),
  234. 'billing_email' => __( 'Email Address', 'woocommerce' ),
  235. 'shipping_phone' => __( 'Shipping Phone Number', 'woocommerce' ),
  236. ),
  237. $order
  238. );
  239. foreach ( $props_to_export as $prop => $name ) {
  240. $value = '';
  241. switch ( $prop ) {
  242. case 'items':
  243. $item_names = array();
  244. foreach ( $order->get_items() as $item ) {
  245. $item_names[] = $item->get_name() . ' x ' . $item->get_quantity();
  246. }
  247. $value = implode( ', ', $item_names );
  248. break;
  249. case 'date_created':
  250. $value = wc_format_datetime( $order->get_date_created(), get_option( 'date_format' ) . ', ' . get_option( 'time_format' ) );
  251. break;
  252. case 'formatted_billing_address':
  253. case 'formatted_shipping_address':
  254. $value = preg_replace( '#<br\s*/?>#i', ', ', $order->{"get_$prop"}() );
  255. break;
  256. default:
  257. if ( is_callable( array( $order, 'get_' . $prop ) ) ) {
  258. $value = $order->{"get_$prop"}();
  259. }
  260. break;
  261. }
  262. $value = apply_filters( 'woocommerce_privacy_export_order_personal_data_prop', $value, $prop, $order );
  263. if ( $value ) {
  264. $personal_data[] = array(
  265. 'name' => $name,
  266. 'value' => $value,
  267. );
  268. }
  269. }
  270. // Export meta data.
  271. $meta_to_export = apply_filters(
  272. 'woocommerce_privacy_export_order_personal_data_meta',
  273. array(
  274. 'Payer first name' => __( 'Payer first name', 'woocommerce' ),
  275. 'Payer last name' => __( 'Payer last name', 'woocommerce' ),
  276. 'Payer PayPal address' => __( 'Payer PayPal address', 'woocommerce' ),
  277. 'Transaction ID' => __( 'Transaction ID', 'woocommerce' ),
  278. )
  279. );
  280. if ( ! empty( $meta_to_export ) && is_array( $meta_to_export ) ) {
  281. foreach ( $meta_to_export as $meta_key => $name ) {
  282. $value = apply_filters( 'woocommerce_privacy_export_order_personal_data_meta_value', $order->get_meta( $meta_key ), $meta_key, $order );
  283. if ( $value ) {
  284. $personal_data[] = array(
  285. 'name' => $name,
  286. 'value' => $value,
  287. );
  288. }
  289. }
  290. }
  291. /**
  292. * Allow extensions to register their own personal data for this order for the export.
  293. *
  294. * @since 3.4.0
  295. * @param array $personal_data Array of name value pairs to expose in the export.
  296. * @param WC_Order $order An order object.
  297. */
  298. $personal_data = apply_filters( 'woocommerce_privacy_export_order_personal_data', $personal_data, $order );
  299. return $personal_data;
  300. }
  301. /**
  302. * Get personal data (key/value pairs) for a download object.
  303. *
  304. * @since 3.4.0
  305. * @param WC_Order $download Download object.
  306. * @return array
  307. */
  308. protected static function get_download_personal_data( $download ) {
  309. $personal_data = array(
  310. array(
  311. 'name' => __( 'Download ID', 'woocommerce' ),
  312. 'value' => $download->get_id(),
  313. ),
  314. array(
  315. 'name' => __( 'Order ID', 'woocommerce' ),
  316. 'value' => $download->get_order_id(),
  317. ),
  318. array(
  319. 'name' => __( 'Product', 'woocommerce' ),
  320. 'value' => get_the_title( $download->get_product_id() ),
  321. ),
  322. array(
  323. 'name' => __( 'User email', 'woocommerce' ),
  324. 'value' => $download->get_user_email(),
  325. ),
  326. array(
  327. 'name' => __( 'Downloads remaining', 'woocommerce' ),
  328. 'value' => $download->get_downloads_remaining(),
  329. ),
  330. array(
  331. 'name' => __( 'Download count', 'woocommerce' ),
  332. 'value' => $download->get_download_count(),
  333. ),
  334. array(
  335. 'name' => __( 'Access granted', 'woocommerce' ),
  336. 'value' => gmdate( 'Y-m-d', $download->get_access_granted( 'edit' )->getTimestamp() ),
  337. ),
  338. array(
  339. 'name' => __( 'Access expires', 'woocommerce' ),
  340. 'value' => ! is_null( $download->get_access_expires( 'edit' ) ) ? gmdate( 'Y-m-d', $download->get_access_expires( 'edit' )->getTimestamp() ) : null,
  341. ),
  342. );
  343. /**
  344. * Allow extensions to register their own personal data for this download for the export.
  345. *
  346. * @since 3.4.0
  347. * @param array $personal_data Array of name value pairs to expose in the export.
  348. * @param WC_Order $order An order object.
  349. */
  350. $personal_data = apply_filters( 'woocommerce_privacy_export_download_personal_data', $personal_data, $download );
  351. return $personal_data;
  352. }
  353. /**
  354. * Finds and exports payment tokens by email address for a customer.
  355. *
  356. * @since 3.4.0
  357. * @param string $email_address The user email address.
  358. * @param int $page Page.
  359. * @return array An array of personal data in name value pairs
  360. */
  361. public static function customer_tokens_exporter( $email_address, $page ) {
  362. $user = get_user_by( 'email', $email_address ); // Check if user has an ID in the DB to load stored personal data.
  363. $data_to_export = array();
  364. if ( ! $user instanceof WP_User ) {
  365. return array(
  366. 'data' => $data_to_export,
  367. 'done' => true,
  368. );
  369. }
  370. $tokens = WC_Payment_Tokens::get_tokens(
  371. array(
  372. 'user_id' => $user->ID,
  373. 'limit' => 10,
  374. 'page' => $page,
  375. )
  376. );
  377. if ( 0 < count( $tokens ) ) {
  378. foreach ( $tokens as $token ) {
  379. $data_to_export[] = array(
  380. 'group_id' => 'woocommerce_tokens',
  381. 'group_label' => __( 'Payment Tokens', 'woocommerce' ),
  382. 'group_description' => __( 'User&#8217;s WooCommerce payment tokens data.', 'woocommerce' ),
  383. 'item_id' => 'token-' . $token->get_id(),
  384. 'data' => array(
  385. array(
  386. 'name' => __( 'Token', 'woocommerce' ),
  387. 'value' => $token->get_display_name(),
  388. ),
  389. ),
  390. );
  391. }
  392. $done = 10 > count( $tokens );
  393. } else {
  394. $done = true;
  395. }
  396. return array(
  397. 'data' => $data_to_export,
  398. 'done' => $done,
  399. );
  400. }
  401. }