File: /var/www/epamokos.kaunokolegija.lt/wp-content/plugins/wp-user-frontend/includes/WPUF_Privacy.php
<?php
namespace WeDevs\Wpuf;
use WP_User;
/**
* Class WPUF_Privacy
*
* Add Exporters and Erasers to WP data exporter
*
* @since 2.8.9
*/
class WPUF_Privacy {
private $name = 'WP User Frontend';
public function __construct() {
add_action( 'admin_init', [ $this, 'add_privacy_message' ] );
add_filter( 'wp_privacy_personal_data_exporters', [ $this, 'register_exporters' ], 10 );
add_filter( 'wp_privacy_personal_data_erasers', [ $this, 'register_erasers' ], 10 );
add_filter( 'wpuf_privacy_user_data', [ $this, 'export_billing_address' ], 5, 3 );
}
public function add_privacy_message() {
if ( function_exists( 'wp_add_privacy_policy_content' ) ) {
$content = $this->get_privacy_message();
wp_add_privacy_policy_content( $this->name, $content );
}
}
/**
* Add privacy policy content for the privacy policy page.
*/
public function get_privacy_message() {
$content = '
<div class="wp-suggested-text">' .
'<p class="privacy-policy-tutorial">' .
__( 'This sample policy includes the basics around what personal data you may be collecting, storing and sharing, as well as who may have access to that data. Depending on what settings are enabled and which additional plugins are used, the specific information shared by your form will vary. We recommend consulting with a lawyer when deciding what information to disclose on your privacy policy.', 'wp-user-frontend' ) .
'</p>' .
'<p>' . __( 'We collect information about you during the form submission process on our WordPress website.', 'wp-user-frontend' ) . '</p>' .
'<h2>' . __( 'What we collect and store', 'wp-user-frontend' ) . '</h2>' .
'<p>' . __( 'While you visit our , we’ll track:', 'wp-user-frontend' ) . '</p>' .
'<ul>' .
'<li>' . __( 'Form Fields Data: Forms Fields data includes the available field types when creating a form. We’ll use this to, for example, collect informations like Name, Email and other available fields.', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Location, IP address and browser type: we’ll use this for purposes like estimating taxes and shipping. Also, for reducing fraudulent activities and prevent identity theft while placing orders', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Transaction Details: we’ll ask you to enter this so we can, for instance, provide & regulate subscription packs that you bought and keep track of your payment details for subscription packs!', 'wp-user-frontend' ) . '</li>' .
'</ul>' .
'<p>' . __( 'We’ll also use cookies to keep track of form elements while you’re browsing our site.', 'wp-user-frontend' ) . '</p>' .
'<p class="privacy-policy-tutorial">' . __( 'Note: you may want to further detail your cookie policy, and link to that section from here.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'When you fill up a form, we’ll ask you to provide information including your name, billing address, shipping address, email address, phone number, credit card/payment details and optional account information like username and password and any other form fields found in the form building options. We’ll use this information for purposes, such as, to:', 'wp-user-frontend' ) . '</p>' .
'<ul>' .
'<li>' . __( 'Send you information about your account and order', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Respond to your requests, including transaction details and complaints', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Process payments and prevent fraud', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Set up your account', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Comply with any legal obligations we have, such as calculating taxes', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Improve our form offerings', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Send you marketing messages, if you choose to receive them', 'wp-user-frontend' ) . '</li>' .
'</ul>' .
'<p>' . __( 'If you create an account, we will store your name, address, email and phone number, which will be used to populate the form fields for future submissions.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'We generally store information about you for as long as we need the information for the purposes for which we collect and use it, and we are not legally required to continue keeping it. For example, we will store form submission information for XXX years for tax, accounting and marketing purposes. This includes your name, email address and billing and shipping addresses.', 'wp-user-frontend' ) . '</p>' .
'<h2>' . __( 'Who on our team has access', 'wp-user-frontend' ) . '</h2>' .
'<p>' . __( 'Members of our team have access to the information you provide us. For example, Administrators and Editors and any body else who has permission can access:', 'wp-user-frontend' ) . '</p>' .
'<ul>' .
'<li>' . __( 'Form submission information and other details related to it', 'wp-user-frontend' ) . '</li>' .
'<li>' . __( 'Customer information like your name, email address, and billing and shipping information.', 'wp-user-frontend' ) . '</li>' .
'</ul>' .
'<p>' . __( 'Our team members have access to this information to help fulfill transactions and support you.', 'wp-user-frontend' ) . '</p>' .
'<h2>' . __( 'What we share with others', 'wp-user-frontend' ) . '</h2>' .
'<p class="privacy-policy-tutorial">' . __( 'In this section you should list who you’re sharing data with, and for what purpose. This could include, but may not be limited to, analytics, marketing, payment gateways, shipping providers, and third party embeds.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'We share information with third parties who help us provide our orders and store services to you; for example --', 'wp-user-frontend' ) . '</p>' .
'<h3>' . __( 'Payments', 'wp-user-frontend' ) . '</h3>' .
'<p class="privacy-policy-tutorial">' . __( 'In this subsection you should list which third party payment processors you’re using to take payments on your site since these may handle customer data. We’ve included PayPal as an example, but you should remove this if you’re not using PayPal.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'We accept payments through PayPal. When processing payments, some of your data will be passed to PayPal, including information required to process or support the payment, such as the purchase total and billing information.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'Please see the <a href="https://www.paypal.com/us/webapps/mpp/ua/privacy-full">PayPal Privacy Policy</a> for more details.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'Also, we accept payments through Stripe. When processing payments, some of your data will be passed to Stripe, including information required to process or support the payment, such as the purchase total and billing information.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'Please see the <a href="https://stripe.com/us/privacy">Stripe Privacy Policy</a> for more details.', 'wp-user-frontend' ) . '</p>' .
'<h3>' . __( 'Available Modules', 'wp-user-frontend' ) . '</h3>' .
'<p>' . __( 'In this subsection you should list which third party modules you’re using to increase the functionality of your created forms using WP User Frontend since these may handle customer data.', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'WP User Frontend Pro comes with support for modules like MailChimp, ConvertKit, Stipe, Paid Membership Pro, MailPoet, Zapier, GetResponse, MailPoet 3, Campaign Monitor, Social Login, BuddyPress. Please note any future modules that will be added will have some data transferred to their own platform which falls in their own data policy. ', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'As an example while using MailChimp for your marketing email automation service by integrating it with WP User Frontend, some of your data will be passed to MailChimp, including information required to process or support the email marketing services, such as name, email address and any other information that you intend to pass or collect including all collected information through subscription. ', 'wp-user-frontend' ) . '</p>' .
'<p>' . __( 'Please see the <a href="https://mailchimp.com/legal/privacy/">MailChimp Privacy Policy</a> for more details.', 'wp-user-frontend' ) . '</p>' .
'</div>';
return apply_filters( 'wpuf_privacy_policy_content', $content );
}
/**
* Register WPUF Exporter to export data
*
* @param $exporters
*
* @return array
*/
public function register_exporters( $exporters ) {
$exporters['wpuf-personal-data-export'] = [
'exporter_friendly_name' => __( 'WPUF User Data', 'wp-user-frontend' ),
'callback' => [ 'WPUF_Privacy', 'export_user_data'],
];
$exporters['wpuf-subscription-data-export'] = [
'exporter_friendly_name' => __( 'WPUF Subscription Data', 'wp-user-frontend' ),
'callback' => [ 'WPUF_Privacy', 'export_subscription_data'],
];
$exporters['wpuf-transaction-data-export'] = [
'exporter_friendly_name' => __( 'WPUF Transaction Data', 'wp-user-frontend' ),
'callback' => [ 'WPUF_Privacy', 'export_transaction_data'],
];
$exporters['wpuf-post-data-export'] = [
'exporter_friendly_name' => __( 'WPUF Post Data', 'wp-user-frontend' ),
'callback' => [ 'WPUF_Privacy', 'export_post_data'],
];
return apply_filters( 'wpuf_privacy_register_exporters', $exporters );
}
/**
* Register WPUF Eraser to delete data
*
* @param $erasers
*
* @return array
*/
public function register_erasers( $erasers ) {
$erasers['wpuf-personal-data-erase'] = [
'eraser_friendly_name' => __( 'WPUF User Data', 'wp-user-frontend' ),
'callback' => [ 'WPUF_Privacy', 'erase_user_data'],
];
return apply_filters( 'wpuf_privacy_register_erasers', $erasers );
}
/**
* Get WP_User for given $email address
*
* @param string $email
*
* @return WP_User | String
*/
public static function get_user( $email ) {
$user = get_user_by( 'email', $email );
if ( $user ) {
$wpuf_user = new WPUF_User( $user );
return $wpuf_user;
}
return $email;
}
/**
* Finds and exports customer data by email address.
*
* @param string $email_address the user email address
* @param int $page page
*
* @return array An array of data in name value pairs
*/
public static function export_user_data( $email_address, $page ) {
$data_to_export = [];
$wpuf_user = self::get_user( $email_address );
$data_to_export[] = [
'group_id' => 'wpuf-user-data',
'group_label' => __( 'WPUF User Data', 'wp-user-frontend' ),
'group_description' => __( 'WP User Frontend user data.', 'wp-user-frontend' ),
'item_id' => 'wpuf-user',
'data' => apply_filters( 'wpuf_privacy_user_data', [], $wpuf_user, $page ),
];
/**
* Filters the export data array
*
* @param array
*/
$data_to_export = apply_filters( 'wpuf_privacy_export_data', $data_to_export, $wpuf_user, $page );
return [
'data' => $data_to_export,
'done' => true,
];
}
/**
* Erases personal data associated with an email address from the WPUF user data
*
* @param string $email_address
* @param int $page
*
* @return array
*/
public static function erase_user_data( $email_address, $page = 1 ) {
if ( empty( $email_address ) ) {
return [
'items_removed' => false,
'items_retained' => false,
'messages' => [],
'done' => true,
];
}
$posts = self::get_post_data( $email_address, $page );
$post_ids = wp_list_pluck( $posts, 'id' );
global $wpdb;
$ids = sprintf( '(%s)', implode( ',', $post_ids ) );
$query = "Update `$wpdb->posts` Set `post_author` = 0 WHERE `ID` in $ids";
if ( ! empty( $post_ids ) ) {
$placeholders = implode( ',', array_fill( 0, count( $post_ids ), '%d' ) );
$wpdb->query( $wpdb->prepare(
"UPDATE `$wpdb->posts` SET `post_author` = 0 WHERE `ID` IN ($placeholders)",
$post_ids
));
}
$erased = apply_filters( 'wpuf_erase_user_data', [
'items_removed' => true,
'items_retained' => false,
'messages' => [],
'done' => true,
], $email_address, $page
);
return $erased;
}
/**
* Add Billing address data to export
*
* @param $data
* @param $wpuf_user
* @param $page
*
* @return array
*/
public function export_billing_address( $data, $wpuf_user, $page ) {
if ( !( $wpuf_user instanceof WPUF_User ) ) {
return $data;
}
$address = $wpuf_user->get_billing_address( true );
/**
* @var array
*/
include_once WPUF_ROOT . '/includes/countries.php';
if ( !empty( $address ) ) {
$address_data = [
[
'name' => __( 'Billing Address 1', 'wp-user-frontend' ),
'value' => $address['add_line_1'],
],
[
'name' => __( 'Billing Address 2', 'wp-user-frontend' ),
'value' => $address['add_line_2'],
],
[
'name' => __( 'City', 'wp-user-frontend' ),
'value' => $address['city'],
],
[
'name' => __( 'State', 'wp-user-frontend' ),
'value' => $address['state'],
],
[
'name' => __( 'Zip', 'wp-user-frontend' ),
'value' => $address['zip_code'],
],
[
'name' => __( 'Country', 'wp-user-frontend' ),
'value' => $countries[$address['country']],
],
];
return array_merge( $data, $address_data );
}
return $data;
}
/**
* Export Subscription Data for User
*
* @param $email_address
* @param $page
*
* @return array
*/
public static function export_subscription_data( $email_address, $page ) {
$data_to_export[] = [
'group_id' => 'wpuf-subscription-data',
'group_label' => __( 'WPUF Subscription Data', 'wp-user-frontend' ),
'group_description' => __( 'WP User Frontend subscription data.', 'wp-user-frontend' ),
'item_id' => 'wpuf-subscription',
'data' => self::get_subscription_data( $email_address, $page ),
];
$response = [
'data' => $data_to_export,
'done' => true,
];
return $response;
}
/**
* Export transaction Data for User
*
* @param $email_address
* @param $page
*
* @return array
*/
public static function export_transaction_data( $email_address, $page ) {
$transaction_data = self::get_transaction_data( $email_address, $page );
$data_to_export = [];
if ( !empty( $transaction_data ) ) {
foreach ( $transaction_data as $txn_data ) {
$data_to_export[] = [
'group_id' => 'wpuf-transaction-data',
'group_label' => __( 'WPUF Transaction Data', 'wp-user-frontend' ),
'group_description' => __( 'WP User Frontend transaction data.', 'wp-user-frontend' ),
'item_id' => 'wpuf-transaction' . $txn_data['transaction_id'],
'data' => [
[
'name' => __( 'Transaction ID', 'wp-user-frontend' ),
'value' => $txn_data['transaction_id'],
],
[
'name' => __( 'Payment Status', 'wp-user-frontend' ),
'value' => $txn_data['status'],
],
[
'name' => __( 'Subtotal', 'wp-user-frontend' ),
'value' => $txn_data['subtotal'],
],
[
'name' => __( 'Tax', 'wp-user-frontend' ),
'value' => $txn_data['tax'],
],
[
'name' => __( 'Total', 'wp-user-frontend' ),
'value' => $txn_data['cost'],
],
[
'name' => __( 'Post ID', 'wp-user-frontend' ),
'value' => $txn_data['post_id'],
],
[
'name' => __( 'Pack ID', 'wp-user-frontend' ),
'value' => $txn_data['post_id'],
],
[
'name' => __( 'First Name', 'wp-user-frontend' ),
'value' => $txn_data['payer_first_name'],
],
[
'name' => __( 'Last Name', 'wp-user-frontend' ),
'value' => $txn_data['payer_last_name'],
],
[
'name' => __( 'Email', 'wp-user-frontend' ),
'value' => $txn_data['payer_email'],
],
[
'name' => __( 'Payment Type', 'wp-user-frontend' ),
'value' => $txn_data['payment_type'],
],
[
'name' => __( 'payer_address', 'wp-user-frontend' ),
'value' => implode( ', ', array_map(
function ( $v, $k ) {
return sprintf( "%s='%s'", $k, $v );
},
maybe_unserialize( $txn_data['payer_address'] ),
array_keys( maybe_unserialize( $txn_data['payer_address'] ) )
) ),
],
[
'name' => __( 'Transaction Date', 'wp-user-frontend' ),
'value' => $txn_data['created'],
],
],
];
}
}
$response = [
'data' => $data_to_export,
'done' => true,
];
return $response;
}
/**
* Export Post Data for User
*
* @param $email_address
* @param $page
*
* @return array
*/
public static function export_post_data( $email_address, $page ) {
$post_data = self::get_post_data( $email_address, $page );
$data_to_export = [];
if ( !empty( $post_data ) ) {
foreach ( $post_data as $data ) {
$data_to_export[] = [
'group_id' => 'wpuf-post-data',
'group_label' => __( 'WPUF Post Data', 'wp-user-frontend' ),
'group_description' => __( 'WP User Frontend post data.', 'wp-user-frontend' ),
'item_id' => 'wpuf-posts-' . $data['id'],
'data' => [
[
'name' => __( 'Post ID', 'wp-user-frontend' ),
'value' => $data['id'],
],
[
'name' => __( 'Post Title', 'wp-user-frontend' ),
'value' => $data['title'],
],
[
'name' => __( 'Post URL', 'wp-user-frontend' ),
'value' => $data['url'],
],
[
'name' => __( 'Post Date', 'wp-user-frontend' ),
'value' => $data['date'],
],
],
];
}
}
$response = [
'data' => $data_to_export,
'done' => true,
];
return $response;
}
/**
* Generate Subscription data to export
*
* @param $email_address
* @param $page
*
* @return array
*/
public static function get_subscription_data( $email_address, $page ) {
$wpuf_user = self::get_user( $email_address );
if ( !( $wpuf_user instanceof WPUF_User ) ) {
return [];
}
$sub_id = $wpuf_user->subscription()->current_pack_id();
if ( !$sub_id ) {
return [];
}
$pack = $wpuf_user->subscription()->current_pack();
$subscription_data = [
[
'name' => __( 'Pack ID', 'wp-user-frontend' ),
'value' => $pack['pack_id'],
],
[
'name' => __( 'Pack Title', 'wp-user-frontend' ),
'value' => get_the_title( $pack['pack_id'] ),
],
[
'name' => __( 'Expiry', 'wp-user-frontend' ),
'value' => $pack['expire'],
],
[
'name' => __( 'Recurring', 'wp-user-frontend' ),
'value' => $pack['recurring'],
],
];
return apply_filters( 'wpuf_privacy_subscription_export_data', $subscription_data, $email_address, $page );
}
/**
* Generate Transaction data to export
*
* @param $wpuf_user
* @param $page
*
* @return array
*/
public static function get_transaction_data( $email_address, $page ) {
$wpuf_user = self::get_user( $email_address );
if ( !( $wpuf_user instanceof WPUF_User ) ) {
return [];
}
$txn_data = $wpuf_user->get_transaction_data( true );
if ( !empty( $txn_data ) ) {
return $txn_data;
}
}
/**
* Generate Post data to export
*
* @param $email_address
* @param $page
*
* @return array
*/
public static function get_post_data( $email_address, $page ) {
$wpuf_user = self::get_user( $email_address );
if ( !( $wpuf_user instanceof WPUF_User ) ) {
return [];
}
$post_data = [];
$allowed_posts = wpuf_get_option( 'export_post_types', 'wpuf_privacy', 'post' );
if ( !empty( $allowed_posts ) ) {
$posts = get_posts( apply_filters( 'wpuf_privacy_post_export_query_args', [
'author' => $wpuf_user->id,
'post_type' => $allowed_posts,
'numberposts' => '-1',
'order' => 'ASC',
], $email_address, $page ) );
foreach ( $posts as $post ) {
$data = [];
$data['id'] = $post->ID;
$data['title'] = $post->post_title;
$data['url'] = $post->guid;
$data['date'] = $post->post_date;
$post_data[] = $data;
}
}
return apply_filters( 'wpuf_privacy_export_post_data', $post_data, $email_address, $page );
}
}