$user, ) ); if ( $customers ) { $user = $customers[0]->user_id; } } // Bail if no user found. if ( empty( $user ) ) { return false; } if ( is_string( $status ) ) { if ( strpos( $status, ',' ) ) { $status = explode( ',', $status ); } else { $status = 'publish' === $status ? 'complete' : $status; $status = array( $status ); } } if ( is_array( $status ) ) { $status = array_unique( $status ); } if ( $pagination ) { if ( get_query_var( 'paged' ) ) { $paged = get_query_var( 'paged' ); } elseif ( get_query_var( 'page' ) ) { $paged = get_query_var( 'page' ); } else { $paged = 1; } } $args = array( 'user' => $user, 'number' => $number, 'status' => $status, 'orderby' => 'date', ); if ( $pagination ) { $args['page'] = $paged; } else { $args['nopaging'] = true; } if ( 'any' === $status ) { unset( $args['status'] ); } $purchases = edd_get_payments( apply_filters( 'edd_get_users_purchases_args', $args ) ); return $purchases ? $purchases : false; } /** * Retrieve products purchased by a specific user. * * @since 2.0 * @since 3.0 Refactored to use new query methods and to be more efficient. * * @param int|string $user User ID or email address. * @param string $status Order status. * * @return WP_Post[]|false Array of products, false otherwise. */ function edd_get_users_purchased_products( $user = 0, $status = 'complete' ) { if ( $status === 'publish' ) { $status = 'complete'; } // Fall back to user ID if ( empty( $user ) ) { $user = get_current_user_id(); } // Bail if no user if ( empty( $user ) ) { return false; } // Try to get customer if ( is_numeric( $user ) ) { $customer = edd_get_customer_by( 'user_id', $user ); } elseif ( is_email( $user ) ) { $customer = edd_get_customer_by( 'email', $user ); } else { return false; } if ( empty( $customer ) ) { return false; } // Fetch the order IDs $number = apply_filters( 'edd_users_purchased_products_payments', 9999999 ); $order_ids = edd_get_orders( array( 'customer_id' => $customer->id, 'fields' => 'ids', 'status' => $status, 'number' => $number, ) ); $product_ids = edd_get_order_items( array( 'order_id__in' => $order_ids, 'number' => $number, 'fields' => 'product_id', ) ); $product_ids = array_unique( $product_ids ); // Bail if no product IDs found. if ( empty( $product_ids ) ) { return false; } $args = apply_filters( 'edd_get_users_purchased_products_args', array( 'include' => $product_ids, 'post_type' => 'download', 'posts_per_page' => -1, ) ); return apply_filters( 'edd_users_purchased_products_list', get_posts( $args ) ); } /** * Checks to see if a user has purchased a product. * * @since 1.0 * @since 3.0 Refactored to be more efficient. * * @param int $user_id User ID. * @param array|int $downloads Download IDs to check against. * @param int $variable_price_id - the variable price ID to check for * * @return bool True if purchased, false otherwise. */ function edd_has_user_purchased( $user_id = 0, $downloads = array(), $variable_price_id = null ) { global $wpdb; // Bail if no user ID passed. if ( empty( $user_id ) ) { return false; } /** * Fires before the queries execute. * * @since 2.7.7 */ do_action( 'edd_has_user_purchased_before', $user_id, $downloads, $variable_price_id ); if ( ! is_array( $downloads ) ) { $downloads = array( $downloads ); } // Bail if no downloads passed. if ( empty( $downloads ) ) { return false; } $number = apply_filters( 'edd_users_purchased_products_payments', 9999999 ); $where_id = "'" . implode( "', '", $wpdb->_escape( $downloads ) ) . "'"; $product_id = "oi.product_id IN ({$where_id})"; $price_id = isset( $variable_price_id ) ? $wpdb->prepare( 'AND oi.price_id = %d', absint( $variable_price_id ) ) : ''; $statuses = "'" . implode( "', '", $wpdb->_escape( edd_get_deliverable_order_item_statuses() ) ). "'"; $status_id = " AND oi.status IN({$statuses})"; // Perform a direct database query as it is more efficient. $sql = $wpdb->prepare(" SELECT COUNT(o.id) AS count FROM {$wpdb->edd_orders} o INNER JOIN {$wpdb->edd_order_items} oi ON o.id = oi.order_id WHERE {$product_id} {$price_id} {$status_id} AND o.type = 'sale' AND user_id = %d LIMIT %d", absint( $user_id ), $number ); $result = (int) $wpdb->get_var( $sql ); $return = 0 === $result ? false : true; /** * @since 2.7.7 * * Filter has purchased result */ return apply_filters( 'edd_has_user_purchased', $return, $user_id, $downloads, $variable_price_id ); } /** * Check if a user has made any purchases. * * @since 1.0 * * @param int $user_id User ID. * @return bool True if user has purchased, false otherwise. */ function edd_has_purchases( $user_id = null ) { // Maybe fallback to logged in user. if ( empty( $user_id ) ) { $user_id = get_current_user_id(); } if ( empty( $user_id ) ) { return false; } $count = edd_count_orders( array( 'user_id' => $user_id ) ); return (bool) $count; } /** * Get purchase statistics for user. * * @since 1.6 * @since 3.0 Updated to use new query method. * * @param int|string $user User ID or email address. * * @return array|false $stats Number of purchases and total amount spent by customer. False otherwise. */ function edd_get_purchase_stats_by_user( $user = '' ) { if ( is_email( $user ) ) { $field = 'email'; } elseif ( is_numeric( $user ) ) { $field = 'user_id'; } else { return false; } $stats = array(); $customer = edd_get_customer_by( $field, $user ); if ( $customer ) { $stats['purchases'] = edd_count_orders( array( $field => $user ) ); $stats['total_spent'] = edd_sanitize_amount( $customer->purchase_value ); } return (array) apply_filters( 'edd_purchase_stats_by_user', $stats, $user ); } /** * Count number of purchases of a customer. * * @since 1.3 * * @param string|int $user User ID or email. * @return int Number of purchases. */ function edd_count_purchases_of_customer( $user = null ) { if ( empty( $user ) ) { $user = get_current_user_id(); } $stats = ! empty( $user ) ? edd_get_purchase_stats_by_user( $user ) : false; return isset( $stats['purchases'] ) ? $stats['purchases'] : 0; } /** * Calculates the total amount spent by a user * * @since 1.3 * @param mixed $user - ID or email * @return float - the total amount the user has spent */ function edd_purchase_total_of_user( $user = null ) { $stats = edd_get_purchase_stats_by_user( $user ); return isset( $stats['total_spent'] ) ? $stats['total_spent'] : 0.00; } /** * Counts the total number of files a user (or customer if an email address is * given) has downloaded * * @since 1.3 * @since 3.0 Updated to use edd_count_file_download_logs. * @param mixed $user - ID or email * @return int - The total number of files the user has downloaded */ function edd_count_file_downloads_of_user( $user ) { // If we got an email, look up the customer ID and call the direct query // for customer download counts. if ( is_email( $user ) ) { return edd_count_file_downloads_of_customer( $user ); } $customer = edd_get_customer_by( 'user_id', $user ); return ! empty( $customer->id ) ? edd_count_file_download_logs( array( 'customer_id' => $customer->id, ) ) : 0; } /** * Counts the total number of files a customer has downloaded. * * @since unknown * @since 3.0 Updated to use edd_count_file_download_logs. * @param string|int $customer_id_or_email The email address or id of the customer. * * @return int The total number of files the customer has downloaded. */ function edd_count_file_downloads_of_customer( $customer_id_or_email = '' ) { $customer = new EDD_Customer( $customer_id_or_email ); return edd_count_file_download_logs( array( 'customer_id' => $customer->id, ) ); } /** * Validate a potential username * * @since 1.3.4 * @param string $username The username to validate * @return bool */ function edd_validate_username( $username ) { $sanitized = sanitize_user( $username, false ); $valid = ( $sanitized == $username ); return (bool) apply_filters( 'edd_validate_username', $valid, $username ); } /** * Attach the customer to an existing user account when completing guest purchase. * * This only runs when a user account already exists and a guest purchase is made * with the account's email address. * * After attaching the customer to the user ID, the account is set to pending. * * @since 2.8 * @param bool $success True if payment was added successfully, false otherwise. * @param int $payment_id The ID of the EDD_Payment that was added. * @param int $customer_id The ID of the EDD_Customer object. * @param object $customer The EDD_Customer object. * @return void */ function edd_connect_guest_customer_to_existing_user( $success, $payment_id, $customer_id, $customer ) { // If for some reason we don't get a customer object here, return. if ( ! $customer instanceof EDD_Customer ) { return; } if ( ! empty( $customer->user_id ) ) { return; } $user = get_user_by( 'email', $customer->email ); if ( ! $user instanceof WP_User ) { return; } $customer->update( array( 'user_id' => $user->ID ) ); // Set a flag to force the account to be verified before purchase history can be accessed. edd_set_user_to_pending( $user->ID ); edd_send_user_verification_email( $user->ID ); } add_action( 'edd_customer_post_attach_payment', 'edd_connect_guest_customer_to_existing_user', 10, 4 ); /** * Attach the newly created user_id to a customer, if one exists * * @since 2.4.6 * @param int $user_id The User ID that was created * @return void */ function edd_connect_existing_customer_to_new_user( $user_id ) { $email = get_the_author_meta( 'user_email', $user_id ); // Update the user ID on the customer $customer = new EDD_Customer( $email ); if( $customer->id > 0 ) { $customer->update( array( 'user_id' => $user_id ) ); } } add_action( 'user_register', 'edd_connect_existing_customer_to_new_user', 10, 1 ); /** * Looks up purchases by email that match the registering user * * This is for users that purchased as a guest and then came * back and created an account. * * @since 1.6 * @param int $user_id - the new user's ID * @return void */ function edd_add_past_purchases_to_new_user( $user_id ) { $email = get_the_author_meta( 'user_email', $user_id ); if ( empty( $email ) ) { return; } $payments = edd_get_payments( array( 's' => $email, 'output' => 'payments' ) ); if( $payments ) { // Set a flag to force the account to be verified before purchase history can be accessed edd_set_user_to_pending( $user_id ); edd_send_user_verification_email( $user_id ); foreach( $payments as $payment ) { if ( is_object( $payment ) && $payment instanceof EDD_Payment ) { if ( intval( $payment->user_id ) > 0 ) { continue; // This payment already associated with an account } $payment->user_id = $user_id; $payment->save(); } } } } add_action( 'user_register', 'edd_add_past_purchases_to_new_user', 10, 1 ); /** * Counts the total number of customers. * * @since 1.7 * @return int - The total number of customers. */ function edd_count_total_customers( $args = array() ) { return edd_count_customers(); } /** * Returns the saved address for a customer * * @since 1.8 * @since 3.0 Update to use new query methods. * @param int $user_id User ID. * @return array Customer address. */ function edd_get_customer_address( $user_id = 0 ) { // Maybe fall back to logged in user ID. if ( empty( $user_id ) ) { $user_id = get_current_user_id(); } $customer = edd_get_customer_by( 'user_id', $user_id ); $parsed_address = array(); if ( $customer ) { $address = $customer->get_address(); if ( $address instanceof EDD\Customers\Customer_Address ) { $parsed_address = array( 'line1' => $address->address, 'line2' => $address->address2, 'city' => $address->city, 'zip' => $address->postal_code, 'country' => $address->country, 'state' => $address->region, ); } } $address = wp_parse_args( $parsed_address, array( 'line1' => '', 'line2' => '', 'city' => '', 'zip' => '', 'country' => '', 'state' => '', ) ); return $address; } /** * Sends the new user notification email when a user registers during checkout * * @since 1.8.8 * @param int $user_id * @param array $user_data * * @return void */ function edd_new_user_notification( $user_id = 0, $user_data = array() ) { if( empty( $user_id ) || empty( $user_data ) ) { return; } $emails = EDD()->emails; $from_name = edd_get_option( 'from_name', wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ) ); $from_email = edd_get_option( 'from_email', get_bloginfo( 'admin_email' ) ); // Setup and send the new user email for Admins. $emails->__set( 'from_name', $from_name ); $emails->__set( 'from_email', $from_email ); /* translators: Site name */ $admin_subject = apply_filters( 'edd_user_registration_admin_email_subject', sprintf( __( '[%s] New User Registration', 'easy-digital-downloads' ), $from_name ), $user_data ); $admin_heading = apply_filters( 'edd_user_registration_admin_email_heading', __( 'New user registration', 'easy-digital-downloads' ), $user_data ); /* translators: the username */ $admin_message = sprintf( __( 'Username: %s', 'easy-digital-downloads' ), $user_data['user_login'] ) . "\r\n\r\n"; /* translators: the user email */ $admin_message .= sprintf( __( 'E-mail: %s', 'easy-digital-downloads' ), $user_data['user_email'] ) . "\r\n"; $admin_message = apply_filters( 'edd_user_registration_admin_email_message', $admin_message, $user_data ); $emails->__set( 'heading', $admin_heading ); $emails->send( get_option( 'admin_email' ), $admin_subject, $admin_message ); // Setup and send the new user email for the end user. /* translators: Site name */ $user_subject = apply_filters( 'edd_user_registration_email_subject', sprintf( __( '[%s] Your username and password', 'easy-digital-downloads' ), $from_name ), $user_data ); $user_heading = apply_filters( 'edd_user_registration_email_heading', __( 'Your account info', 'easy-digital-downloads' ), $user_data ); $user_message = apply_filters( 'edd_user_registration_email_username', sprintf( __( 'Username: %s', 'easy-digital-downloads' ), $user_data['user_login'] ) . "\r\n", $user_data ); if ( did_action( 'edd_pre_process_purchase' ) ) { $password_message = __( 'Password entered at checkout', 'easy-digital-downloads' ); } else { $password_message = __( 'Password entered at registration', 'easy-digital-downloads' ); } /* translators: %s: password message */ $user_message .= apply_filters( 'edd_user_registration_email_password', sprintf( __( 'Password: %s', 'easy-digital-downloads' ), '[' . $password_message . ']' ) . "\r\n" ); $login_url = apply_filters( 'edd_user_registration_email_login_url', wp_login_url() ); if( $emails->html ) { $user_message .= ' ' . esc_attr__( 'Click here to log in', 'easy-digital-downloads' ) . ' →' . "\r\n"; } else { /* translators: %s: login URL */ $user_message .= sprintf( __( 'To log in, visit: %s', 'easy-digital-downloads' ), esc_url( $login_url ) ) . "\r\n"; } $user_message = apply_filters( 'edd_user_registration_email_message', $user_message, $user_data ); $emails->__set( 'heading', $user_heading ); $emails->send( $user_data['user_email'], $user_subject, $user_message ); } add_action( 'edd_insert_user', 'edd_new_user_notification', 10, 2 ); /** * Set a user's status to pending * * @since 2.4.4 * @param integer $user_id The User ID to set to pending * @return bool If the update was successful */ function edd_set_user_to_pending( $user_id = 0 ) { if ( empty( $user_id ) ) { return false; } do_action( 'edd_pre_set_user_to_pending', $user_id ); $update_successful = (bool) update_user_meta( $user_id, '_edd_pending_verification', '1' ); do_action( 'edd_post_set_user_to_pending', $user_id, $update_successful ); return $update_successful; } /** * Set the user from pending to active * * @since 2.4.4 * @param integer $user_id The User ID to activate * @return bool If the user was marked as active or not */ function edd_set_user_to_verified( $user_id = 0 ) { if ( empty( $user_id ) ) { return false; } if ( ! edd_user_pending_verification( $user_id ) ) { return false; } do_action( 'edd_pre_set_user_to_active', $user_id ); $update_successful = delete_user_meta( $user_id, '_edd_pending_verification', '1' ); do_action( 'edd_post_set_user_to_active', $user_id, $update_successful ); return $update_successful; } /** * Determines if the user account is pending verification. Pending accounts cannot view purchase history * * @since 2.4.4 * @return bool */ function edd_user_pending_verification( $user_id = null ) { if( is_null( $user_id ) ) { $user_id = get_current_user_id(); } // No need to run a DB lookup on an empty user id if ( empty( $user_id ) ) { return false; } $pending = get_user_meta( $user_id, '_edd_pending_verification', true ); return (bool) apply_filters( 'edd_user_pending_verification', ! empty( $pending ), $user_id ); } /** * Gets the activation URL for the specified user * * @since 2.4.4 * @return string */ function edd_get_user_verification_url( $user_id = 0 ) { if( empty( $user_id ) ) { return false; } $base_url = add_query_arg( array( 'edd_action' => 'verify_user', 'user_id' => absint( $user_id ), 'ttl' => strtotime( '+24 hours' ) ), untrailingslashit( edd_get_user_verification_page() ) ); $token = edd_get_user_verification_token( $base_url ); $url = add_query_arg( 'token', $token, $base_url ); return apply_filters( 'edd_get_user_verification_url', $url, $user_id ); } /** * Gets the URL that triggers a new verification email to be sent * * @since 2.4.4 * @return string */ function edd_get_user_verification_request_url( $user_id = 0 ) { if( empty( $user_id ) ) { $user_id = get_current_user_id(); } $url = esc_url( wp_nonce_url( add_query_arg( array( 'edd_action' => 'send_verification_email' ) ), 'edd-request-verification' ) ); return apply_filters( 'edd_get_user_verification_request_url', $url, $user_id ); } /** * Sends an email to the specified user with a URL to verify their account * * @since 2.4.4 * @param int $user_id */ function edd_send_user_verification_email( $user_id = 0 ) { if( empty( $user_id ) ) { return; } if( ! edd_user_pending_verification( $user_id ) ) { return; } $user_data = get_userdata( $user_id ); if( ! $user_data ) { return; } $name = $user_data->display_name; $url = edd_get_user_verification_url( $user_id ); $from_name = edd_get_option( 'from_name', wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ) ); $from_email = edd_get_option( 'from_email', get_bloginfo( 'admin_email' ) ); $subject = apply_filters( 'edd_user_verification_email_subject', __( 'Verify your account', 'easy-digital-downloads' ), $user_id ); $heading = apply_filters( 'edd_user_verification_email_heading', __( 'Verify your account', 'easy-digital-downloads' ), $user_id ); $message = sprintf( /* translators: 1: User display name, 2: Site name, 3: Verification URL */ __( 'Hello %1$s, Your account with %2$s needs to be verified before you can access your purchase history. Click here to verify your account. Link missing? Visit the following URL: %3$s', 'easy-digital-downloads' ), $name, $from_name, esc_url_raw( $url ), // This parameter is not used, but is added for compatibility with past translations. esc_url_raw( $url ) ); $message = apply_filters( 'edd_user_verification_email_message', $message, $user_id ); $emails = new EDD_Emails; $emails->__set( 'from_name', $from_name ); $emails->__set( 'from_email', $from_email ); $emails->__set( 'heading', $heading ); $emails->send( $user_data->user_email, $subject, $message ); } /** * Generates a token for a user verification URL. * * An 'o' query parameter on a URL can include optional variables to test * against when verifying a token without passing those variables around in * the URL. For example, downloads can be limited to the IP that the URL was * generated for by adding 'o=ip' to the query string. * * Or suppose when WordPress requested a URL for automatic updates, the user * agent could be tested to ensure the URL is only valid for requests from * that user agent. * * @since 2.4.4 * * @param string $url The URL to generate a token for. * @return string The token for the URL. */ function edd_get_user_verification_token( $url = '' ) { $args = array(); $hash = apply_filters( 'edd_get_user_verification_token_algorithm', 'sha256' ); $secret = apply_filters( 'edd_get_user_verification_token_secret', hash( $hash, wp_salt() ) ); /* * Add additional args to the URL for generating the token. * Allows for restricting access to IP and/or user agent. */ $parts = parse_url( $url ); $options = array(); if ( isset( $parts['query'] ) ) { wp_parse_str( $parts['query'], $query_args ); // o = option checks (ip, user agent). if ( ! empty( $query_args['o'] ) ) { // Multiple options can be checked by separating them with a colon in the query parameter. $options = explode( ':', rawurldecode( $query_args['o'] ) ); if ( in_array( 'ip', $options ) ) { $args['ip'] = edd_get_ip(); } if ( in_array( 'ua', $options ) ) { $ua = isset( $_SERVER['HTTP_USER_AGENT'] ) ? $_SERVER['HTTP_USER_AGENT'] : ''; $args['user_agent'] = rawurlencode( $ua ); } } } /* * Filter to modify arguments and allow custom options to be tested. * Be sure to rawurlencode any custom options for consistent results. */ $args = apply_filters( 'edd_get_user_verification_token_args', $args, $url, $options ); $args['secret'] = $secret; $args['token'] = false; // Removes a token if present. $url = add_query_arg( $args, $url ); $parts = parse_url( $url ); // In the event there isn't a path, set an empty one so we can MD5 the token if ( ! isset( $parts['path'] ) ) { $parts['path'] = ''; } $token = md5( $parts['path'] . '?' . $parts['query'] ); return $token; } /** * Generate a token for a URL and match it against the existing token to make * sure the URL hasn't been tampered with. * * @since 2.4.4 * * @param string $url URL to test. * @return bool */ function edd_validate_user_verification_token( $url = '' ) { $ret = false; $parts = parse_url( $url ); $query_args = array(); if ( isset( $parts['query'] ) ) { wp_parse_str( $parts['query'], $query_args ); if ( isset( $query_args['ttl'] ) && current_time( 'timestamp' ) > $query_args['ttl'] ) { do_action( 'edd_user_verification_token_expired' ); $link_text = sprintf( /* translators: %s: URL to request a new verification link */ __( 'Sorry but your account verification link has expired. Click here to request a new verification URL.', 'easy-digital-downloads' ), esc_url( edd_get_user_verification_request_url() ) ); wp_die( apply_filters( 'edd_verification_link_expired_text', $link_text ), __( 'Error', 'easy-digital-downloads' ), array( 'response' => 403 ) ); } if ( isset( $query_args['token'] ) && $query_args['token'] == edd_get_user_verification_token( $url ) ) { $ret = true; } } return apply_filters( 'edd_validate_user_verification_token', $ret, $url, $query_args ); } /** * Processes an account verification email request * * @since 2.4.4 * * @return void */ function edd_process_user_verification_request() { if( ! wp_verify_nonce( $_GET['_wpnonce'], 'edd-request-verification' ) ) { wp_die( __( 'Nonce verification failed.', 'easy-digital-downloads' ), __( 'Error', 'easy-digital-downloads' ), array( 'response' => 403 ) ); } if( ! is_user_logged_in() ) { wp_die( __( 'You must be logged in to verify your account.', 'easy-digital-downloads' ), __( 'Notice', 'easy-digital-downloads' ), array( 'response' => 403 ) ); } if( ! edd_user_pending_verification( get_current_user_id() ) ) { wp_die( __( 'Your account has already been verified.', 'easy-digital-downloads' ), __( 'Notice', 'easy-digital-downloads' ), array( 'response' => 403 ) ); } edd_send_user_verification_email( get_current_user_id() ); $redirect = apply_filters( 'edd_user_account_verification_request_redirect', add_query_arg( 'edd-verify-request', '1', edd_get_user_verification_page() ) ); edd_redirect( $redirect ); } add_action( 'edd_send_verification_email', 'edd_process_user_verification_request' ); /** * Processes an account verification * * @since 2.4.4 * * @return void */ function edd_process_user_account_verification() { if( empty( $_GET['token'] ) ) { return false; } if( empty( $_GET['user_id'] ) ) { return false; } if( empty( $_GET['ttl'] ) ) { return false; } $parts = parse_url( add_query_arg( array() ) ); wp_parse_str( $parts['query'], $query_args ); $url = add_query_arg( $query_args, untrailingslashit( edd_get_user_verification_page() ) ); if( ! edd_validate_user_verification_token( $url ) ) { do_action( 'edd_invalid_user_verification_token' ); wp_die( __( 'Invalid verification token provided.', 'easy-digital-downloads' ), __( 'Error', 'easy-digital-downloads' ), array( 'response' => 403 ) ); } edd_set_user_to_verified( absint( $_GET['user_id'] ) ); do_action( 'edd_user_verification_token_validated' ); $redirect = apply_filters( 'edd_user_account_verified_redirect', add_query_arg( 'edd-verify-success', '1', edd_get_user_verification_page() ) ); edd_redirect( $redirect ); } add_action( 'edd_verify_user', 'edd_process_user_account_verification' ); /** * Retrieves the purchase history page, or main URL for the account verification process * * @since 2.4.6 * @return string The base URL to use for account verification */ function edd_get_user_verification_page() { $url = home_url(); $purchase_history = edd_get_option( 'purchase_history_page', 0 ); if ( ! empty( $purchase_history ) ) { $url = get_permalink( $purchase_history ); } return apply_filters( 'edd_user_verification_base_url', $url ); } /** * When a user is deleted, detach that user id from the customer record * * @since 2.5 * @param int $user_id The User ID being deleted * @return bool If the detachment was successful */ function edd_detach_deleted_user( $user_id ) { $customer = new EDD_Customer( $user_id, true ); $detached = false; if ( $customer->id > 0 ) { $detached = $customer->update( array( 'user_id' => 0 ) ); } do_action( 'edd_detach_deleted_user', $user_id, $customer, $detached ); return $detached; } add_action( 'delete_user', 'edd_detach_deleted_user', 10, 1 ); /** * Modify User Profile * * Modifies the output of profile.php to add key generation/revocation * * @since 2.6 * @param object $user Current user info * @return void */ function edd_show_user_api_key_field( $user ) { // Bail if no user, or user ID is not current user if ( empty( $user ) || ( get_current_user_id() !== $user->ID ) ) { return; } /** * Show API User Key Fields * * Allows showing/hiding the user API Key fields. By default will only try to show on admin pages. The filter * allows for developers to choose to show it in other places that the WordPress profile editor hooks are used * like bbPress * * @since 2.9.1 * * @param boolean If EDD should attempt to load the user API fields * @param WP_User The User object currently being viewed. */ $show_fields = apply_filters( 'edd_show_user_api_key_fields', is_admin(), $user ); if ( ! $show_fields ) { return; } if ( ( edd_get_option( 'api_allow_user_keys', false ) || current_user_can( 'manage_shop_settings' ) ) && current_user_can( 'edit_user', $user->ID ) ) { $user = get_userdata( $user->ID ); $public_key = EDD()->api->get_user_public_key( $user->ID ); $secret_key = EDD()->api->get_user_secret_key( $user->ID ); $token = EDD()->api->get_token( $user->ID ); ?>
edd_user_public_key ) ) { ?>
|
iOS App', 'easy-digital-downloads' ), 'https://itunes.apple.com/us/app/easy-digital-downloads-2/id1169488828?ls=1&mt=8' ); ?> |
---|