@@ -700,7 +700,7 @@ discard block |
||
| 700 | 700 | } |
| 701 | 701 | |
| 702 | 702 | function wpinv_get_payment_key( $invoice_id = 0 ) { |
| 703 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 703 | + $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 704 | 704 | return $invoice->get_key(); |
| 705 | 705 | } |
| 706 | 706 | |
@@ -966,7 +966,7 @@ discard block |
||
| 966 | 966 | return false; |
| 967 | 967 | } |
| 968 | 968 | $invoice = wpinv_get_invoice_cart(); |
| 969 | - if ( empty( $invoice ) ) { |
|
| 969 | + if ( empty( $invoice ) ) { |
|
| 970 | 970 | return false; |
| 971 | 971 | } |
| 972 | 972 | |
@@ -1259,20 +1259,20 @@ discard block |
||
| 1259 | 1259 | } |
| 1260 | 1260 | |
| 1261 | 1261 | function wpinv_checkout_get_cc_info() { |
| 1262 | - $cc_info = array(); |
|
| 1263 | - $cc_info['card_name'] = isset( $_POST['card_name'] ) ? sanitize_text_field( $_POST['card_name'] ) : ''; |
|
| 1264 | - $cc_info['card_number'] = isset( $_POST['card_number'] ) ? sanitize_text_field( $_POST['card_number'] ) : ''; |
|
| 1265 | - $cc_info['card_cvc'] = isset( $_POST['card_cvc'] ) ? sanitize_text_field( $_POST['card_cvc'] ) : ''; |
|
| 1266 | - $cc_info['card_exp_month'] = isset( $_POST['card_exp_month'] ) ? sanitize_text_field( $_POST['card_exp_month'] ) : ''; |
|
| 1267 | - $cc_info['card_exp_year'] = isset( $_POST['card_exp_year'] ) ? sanitize_text_field( $_POST['card_exp_year'] ) : ''; |
|
| 1268 | - $cc_info['card_address'] = isset( $_POST['wpinv_address'] ) ? sanitize_text_field( $_POST['wpinv_address'] ) : ''; |
|
| 1269 | - $cc_info['card_city'] = isset( $_POST['wpinv_city'] ) ? sanitize_text_field( $_POST['wpinv_city'] ) : ''; |
|
| 1270 | - $cc_info['card_state'] = isset( $_POST['wpinv_state'] ) ? sanitize_text_field( $_POST['wpinv_state'] ) : ''; |
|
| 1271 | - $cc_info['card_country'] = isset( $_POST['wpinv_country'] ) ? sanitize_text_field( $_POST['wpinv_country'] ) : ''; |
|
| 1272 | - $cc_info['card_zip'] = isset( $_POST['wpinv_zip'] ) ? sanitize_text_field( $_POST['wpinv_zip'] ) : ''; |
|
| 1273 | - |
|
| 1274 | - // Return cc info |
|
| 1275 | - return $cc_info; |
|
| 1262 | + $cc_info = array(); |
|
| 1263 | + $cc_info['card_name'] = isset( $_POST['card_name'] ) ? sanitize_text_field( $_POST['card_name'] ) : ''; |
|
| 1264 | + $cc_info['card_number'] = isset( $_POST['card_number'] ) ? sanitize_text_field( $_POST['card_number'] ) : ''; |
|
| 1265 | + $cc_info['card_cvc'] = isset( $_POST['card_cvc'] ) ? sanitize_text_field( $_POST['card_cvc'] ) : ''; |
|
| 1266 | + $cc_info['card_exp_month'] = isset( $_POST['card_exp_month'] ) ? sanitize_text_field( $_POST['card_exp_month'] ) : ''; |
|
| 1267 | + $cc_info['card_exp_year'] = isset( $_POST['card_exp_year'] ) ? sanitize_text_field( $_POST['card_exp_year'] ) : ''; |
|
| 1268 | + $cc_info['card_address'] = isset( $_POST['wpinv_address'] ) ? sanitize_text_field( $_POST['wpinv_address'] ) : ''; |
|
| 1269 | + $cc_info['card_city'] = isset( $_POST['wpinv_city'] ) ? sanitize_text_field( $_POST['wpinv_city'] ) : ''; |
|
| 1270 | + $cc_info['card_state'] = isset( $_POST['wpinv_state'] ) ? sanitize_text_field( $_POST['wpinv_state'] ) : ''; |
|
| 1271 | + $cc_info['card_country'] = isset( $_POST['wpinv_country'] ) ? sanitize_text_field( $_POST['wpinv_country'] ) : ''; |
|
| 1272 | + $cc_info['card_zip'] = isset( $_POST['wpinv_zip'] ) ? sanitize_text_field( $_POST['wpinv_zip'] ) : ''; |
|
| 1273 | + |
|
| 1274 | + // Return cc info |
|
| 1275 | + return $cc_info; |
|
| 1276 | 1276 | } |
| 1277 | 1277 | |
| 1278 | 1278 | function wpinv_checkout_validate_cc_zip( $zip = 0, $country_code = '' ) { |
@@ -1479,7 +1479,7 @@ discard block |
||
| 1479 | 1479 | $required_fields = wpinv_checkout_required_fields(); |
| 1480 | 1480 | |
| 1481 | 1481 | // Loop through required fields and show error messages |
| 1482 | - if ( !empty( $required_fields ) ) { |
|
| 1482 | + if ( !empty( $required_fields ) ) { |
|
| 1483 | 1483 | foreach ( $required_fields as $field_name => $value ) { |
| 1484 | 1484 | if ( in_array( $value, $required_fields ) && empty( $_POST[ 'wpinv_' . $field_name ] ) ) { |
| 1485 | 1485 | wpinv_set_error( $value['error_id'], $value['error_message'] ); |
@@ -1581,7 +1581,7 @@ discard block |
||
| 1581 | 1581 | } |
| 1582 | 1582 | |
| 1583 | 1583 | function wpinv_get_checkout_session() { |
| 1584 | - global $wpi_session; |
|
| 1584 | + global $wpi_session; |
|
| 1585 | 1585 | return $wpi_session->get( 'wpinv_checkout' ); |
| 1586 | 1586 | } |
| 1587 | 1587 | |
@@ -1661,7 +1661,7 @@ discard block |
||
| 1661 | 1661 | $response['data']['taxf'] = $invoice->get_tax( true ); |
| 1662 | 1662 | $response['data']['total'] = $invoice->get_total(); |
| 1663 | 1663 | $response['data']['totalf'] = $invoice->get_total( true ); |
| 1664 | - $response['data']['free'] = $invoice->is_free() && ( ! ( (float) $response['data']['total'] > 0 ) || $invoice->is_free_trial() ) ? true : false; |
|
| 1664 | + $response['data']['free'] = $invoice->is_free() && ( ! ( (float) $response['data']['total'] > 0 ) || $invoice->is_free_trial() ) ? true : false; |
|
| 1665 | 1665 | |
| 1666 | 1666 | wp_send_json( $response ); |
| 1667 | 1667 | } |
@@ -1731,8 +1731,8 @@ discard block |
||
| 1731 | 1731 | // Allow themes and plugins to hook before the gateway |
| 1732 | 1732 | do_action( 'wpinv_checkout_before_gateway', $_POST, $user_info, $valid_data ); |
| 1733 | 1733 | |
| 1734 | - // If it is free, abort. |
|
| 1735 | - if ( $invoice->is_free() && ( ! $invoice->is_recurring() || 0 == $invoice->get_recurring_details( 'total' ) ) ) { |
|
| 1734 | + // If it is free, abort. |
|
| 1735 | + if ( $invoice->is_free() && ( ! $invoice->is_recurring() || 0 == $invoice->get_recurring_details( 'total' ) ) ) { |
|
| 1736 | 1736 | $invoice_data['gateway'] = 'manual'; |
| 1737 | 1737 | $_POST['wpi-gateway'] = 'manual'; |
| 1738 | 1738 | } |
@@ -1948,52 +1948,52 @@ discard block |
||
| 1948 | 1948 | * Given an invoice key, this function returns the id. |
| 1949 | 1949 | */ |
| 1950 | 1950 | function wpinv_get_invoice_id_by_key( $key ) { |
| 1951 | - global $wpdb; |
|
| 1951 | + global $wpdb; |
|
| 1952 | 1952 | $table = $wpdb->prefix . 'getpaid_invoices'; |
| 1953 | - return (int) $wpdb->get_var( $wpdb->prepare( "SELECT post_id FROM $table WHERE`key` = %s LIMIT 1", $key ) ); |
|
| 1953 | + return (int) $wpdb->get_var( $wpdb->prepare( "SELECT post_id FROM $table WHERE`key` = %s LIMIT 1", $key ) ); |
|
| 1954 | 1954 | } |
| 1955 | 1955 | |
| 1956 | 1956 | function wpinv_can_view_receipt( $invoice_key = '' ) { |
| 1957 | - $return = current_user_can( 'manage_options' ); |
|
| 1957 | + $return = current_user_can( 'manage_options' ); |
|
| 1958 | 1958 | |
| 1959 | - if ( empty( $invoice_key ) ) { |
|
| 1960 | - return false; |
|
| 1961 | - } |
|
| 1959 | + if ( empty( $invoice_key ) ) { |
|
| 1960 | + return false; |
|
| 1961 | + } |
|
| 1962 | 1962 | |
| 1963 | - global $wpinv_receipt_args; |
|
| 1963 | + global $wpinv_receipt_args; |
|
| 1964 | 1964 | |
| 1965 | - $wpinv_receipt_args['id'] = wpinv_get_invoice_id_by_key( $invoice_key ); |
|
| 1966 | - if ( isset( $_GET['invoice-id'] ) ) { |
|
| 1967 | - $wpinv_receipt_args['id'] = $invoice_key == wpinv_get_payment_key( (int)$_GET['invoice-id'] ) ? (int)$_GET['invoice-id'] : 0; |
|
| 1968 | - } |
|
| 1965 | + $wpinv_receipt_args['id'] = wpinv_get_invoice_id_by_key( $invoice_key ); |
|
| 1966 | + if ( isset( $_GET['invoice-id'] ) ) { |
|
| 1967 | + $wpinv_receipt_args['id'] = $invoice_key == wpinv_get_payment_key( (int)$_GET['invoice-id'] ) ? (int)$_GET['invoice-id'] : 0; |
|
| 1968 | + } |
|
| 1969 | 1969 | |
| 1970 | - if ( empty( $wpinv_receipt_args['id'] ) ) { |
|
| 1971 | - return $return; |
|
| 1972 | - } |
|
| 1970 | + if ( empty( $wpinv_receipt_args['id'] ) ) { |
|
| 1971 | + return $return; |
|
| 1972 | + } |
|
| 1973 | 1973 | |
| 1974 | - $invoice = wpinv_get_invoice( $wpinv_receipt_args['id'] ); |
|
| 1975 | - if ( !( !empty( $invoice->ID ) && $invoice->get_key() === $invoice_key ) ) { |
|
| 1976 | - return $return; |
|
| 1977 | - } |
|
| 1974 | + $invoice = wpinv_get_invoice( $wpinv_receipt_args['id'] ); |
|
| 1975 | + if ( !( !empty( $invoice->ID ) && $invoice->get_key() === $invoice_key ) ) { |
|
| 1976 | + return $return; |
|
| 1977 | + } |
|
| 1978 | 1978 | |
| 1979 | - if ( is_user_logged_in() ) { |
|
| 1980 | - if ( (int)$invoice->get_user_id() === (int) get_current_user_id() ) { |
|
| 1981 | - $return = true; |
|
| 1982 | - } |
|
| 1983 | - } |
|
| 1979 | + if ( is_user_logged_in() ) { |
|
| 1980 | + if ( (int)$invoice->get_user_id() === (int) get_current_user_id() ) { |
|
| 1981 | + $return = true; |
|
| 1982 | + } |
|
| 1983 | + } |
|
| 1984 | 1984 | |
| 1985 | - $session = wpinv_get_checkout_session(); |
|
| 1986 | - if ( isset( $_GET['invoice_key'] ) || ( $session && isset( $session['invoice_key'] ) ) ) { |
|
| 1987 | - $check_key = isset( $_GET['invoice_key'] ) ? $_GET['invoice_key'] : $session['invoice_key']; |
|
| 1985 | + $session = wpinv_get_checkout_session(); |
|
| 1986 | + if ( isset( $_GET['invoice_key'] ) || ( $session && isset( $session['invoice_key'] ) ) ) { |
|
| 1987 | + $check_key = isset( $_GET['invoice_key'] ) ? $_GET['invoice_key'] : $session['invoice_key']; |
|
| 1988 | 1988 | |
| 1989 | - if ( wpinv_require_login_to_checkout() ) { |
|
| 1990 | - $return = $return && $check_key == $invoice_key; |
|
| 1991 | - } else { |
|
| 1992 | - $return = $check_key == $invoice_key; |
|
| 1993 | - } |
|
| 1994 | - } |
|
| 1989 | + if ( wpinv_require_login_to_checkout() ) { |
|
| 1990 | + $return = $return && $check_key == $invoice_key; |
|
| 1991 | + } else { |
|
| 1992 | + $return = $check_key == $invoice_key; |
|
| 1993 | + } |
|
| 1994 | + } |
|
| 1995 | 1995 | |
| 1996 | - return (bool) apply_filters( 'wpinv_can_view_receipt', $return, $invoice_key ); |
|
| 1996 | + return (bool) apply_filters( 'wpinv_can_view_receipt', $return, $invoice_key ); |
|
| 1997 | 1997 | } |
| 1998 | 1998 | |
| 1999 | 1999 | function wpinv_pay_for_invoice() { |
@@ -2303,14 +2303,14 @@ discard block |
||
| 2303 | 2303 | |
| 2304 | 2304 | if ( isset( $_GET['invoice_key'] ) || is_singular( 'wpi_invoice' ) || is_singular( 'wpi_quote' ) ) { |
| 2305 | 2305 | $invoice_key = isset( $_GET['invoice_key'] ) ? urldecode($_GET['invoice_key']) : ''; |
| 2306 | - global $post; |
|
| 2306 | + global $post; |
|
| 2307 | 2307 | |
| 2308 | 2308 | if(!empty($invoice_key)){ |
| 2309 | - $invoice_id = wpinv_get_invoice_id_by_key($invoice_key); |
|
| 2309 | + $invoice_id = wpinv_get_invoice_id_by_key($invoice_key); |
|
| 2310 | 2310 | } else if(!empty( $post ) && ($post->post_type == 'wpi_invoice' || $post->post_type == 'wpi_quote')) { |
| 2311 | - $invoice_id = $post->ID; |
|
| 2311 | + $invoice_id = $post->ID; |
|
| 2312 | 2312 | } else { |
| 2313 | - return; |
|
| 2313 | + return; |
|
| 2314 | 2314 | } |
| 2315 | 2315 | |
| 2316 | 2316 | $invoice = new WPInv_Invoice($invoice_id); |
@@ -2319,17 +2319,17 @@ discard block |
||
| 2319 | 2319 | return; |
| 2320 | 2320 | } |
| 2321 | 2321 | |
| 2322 | - if ( is_user_logged_in() ) { |
|
| 2323 | - if ( (int)$invoice->get_user_id() === get_current_user_id() ) { |
|
| 2324 | - update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2325 | - } else if ( !wpinv_require_login_to_checkout() && isset( $_GET['invoice_key'] ) && $_GET['invoice_key'] === $invoice->get_key() ) { |
|
| 2326 | - update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2327 | - } |
|
| 2328 | - } else { |
|
| 2329 | - if ( !wpinv_require_login_to_checkout() && isset( $_GET['invoice_key'] ) && $_GET['invoice_key'] === $invoice->get_key() ) { |
|
| 2330 | - update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2331 | - } |
|
| 2332 | - } |
|
| 2322 | + if ( is_user_logged_in() ) { |
|
| 2323 | + if ( (int)$invoice->get_user_id() === get_current_user_id() ) { |
|
| 2324 | + update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2325 | + } else if ( !wpinv_require_login_to_checkout() && isset( $_GET['invoice_key'] ) && $_GET['invoice_key'] === $invoice->get_key() ) { |
|
| 2326 | + update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2327 | + } |
|
| 2328 | + } else { |
|
| 2329 | + if ( !wpinv_require_login_to_checkout() && isset( $_GET['invoice_key'] ) && $_GET['invoice_key'] === $invoice->get_key() ) { |
|
| 2330 | + update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2331 | + } |
|
| 2332 | + } |
|
| 2333 | 2333 | } |
| 2334 | 2334 | |
| 2335 | 2335 | } |
@@ -7,14 +7,14 @@ discard block |
||
| 7 | 7 | */ |
| 8 | 8 | |
| 9 | 9 | // MUST have WordPress. |
| 10 | -if ( !defined( 'WPINC' ) ) { |
|
| 11 | - exit( 'Do NOT access this file directly: ' . basename( __FILE__ ) ); |
|
| 10 | +if (!defined('WPINC')) { |
|
| 11 | + exit('Do NOT access this file directly: ' . basename(__FILE__)); |
|
| 12 | 12 | } |
| 13 | 13 | |
| 14 | 14 | function wpinv_get_invoice_cart_id() { |
| 15 | 15 | $wpinv_checkout = wpinv_get_checkout_session(); |
| 16 | 16 | |
| 17 | - if ( !empty( $wpinv_checkout['invoice_id'] ) ) { |
|
| 17 | + if (!empty($wpinv_checkout['invoice_id'])) { |
|
| 18 | 18 | return $wpinv_checkout['invoice_id']; |
| 19 | 19 | } |
| 20 | 20 | |
@@ -28,48 +28,48 @@ discard block |
||
| 28 | 28 | * @param bool $wp_error Whether to return false or WP_Error on failure. |
| 29 | 29 | * @return int|WP_Error|WPInv_Invoice The value 0 or WP_Error on failure. The WPInv_Invoice object on success. |
| 30 | 30 | */ |
| 31 | -function wpinv_insert_invoice( $invoice_data = array(), $wp_error = false ) { |
|
| 32 | - if ( empty( $invoice_data ) ) { |
|
| 31 | +function wpinv_insert_invoice($invoice_data = array(), $wp_error = false) { |
|
| 32 | + if (empty($invoice_data)) { |
|
| 33 | 33 | return false; |
| 34 | 34 | } |
| 35 | 35 | |
| 36 | - if ( !( !empty( $invoice_data['cart_details'] ) && is_array( $invoice_data['cart_details'] ) ) ) { |
|
| 37 | - return $wp_error ? new WP_Error( 'wpinv_invalid_items', __( 'Invoice must have atleast one item.', 'invoicing' ) ) : 0; |
|
| 36 | + if (!(!empty($invoice_data['cart_details']) && is_array($invoice_data['cart_details']))) { |
|
| 37 | + return $wp_error ? new WP_Error('wpinv_invalid_items', __('Invoice must have atleast one item.', 'invoicing')) : 0; |
|
| 38 | 38 | } |
| 39 | 39 | |
| 40 | 40 | // If no user id is provided, default to the current user id |
| 41 | - if ( empty( $invoice_data['user_id'] ) ) { |
|
| 41 | + if (empty($invoice_data['user_id'])) { |
|
| 42 | 42 | $invoice_data['user_id'] = get_current_user_id(); |
| 43 | 43 | } |
| 44 | 44 | |
| 45 | - $invoice_data['invoice_id'] = !empty( $invoice_data['invoice_id'] ) ? (int)$invoice_data['invoice_id'] : 0; |
|
| 45 | + $invoice_data['invoice_id'] = !empty($invoice_data['invoice_id']) ? (int) $invoice_data['invoice_id'] : 0; |
|
| 46 | 46 | |
| 47 | - if ( empty( $invoice_data['status'] ) ) { |
|
| 47 | + if (empty($invoice_data['status'])) { |
|
| 48 | 48 | $invoice_data['status'] = 'wpi-pending'; |
| 49 | 49 | } |
| 50 | 50 | |
| 51 | - if ( empty( $invoice_data['post_type'] ) ) { |
|
| 51 | + if (empty($invoice_data['post_type'])) { |
|
| 52 | 52 | $invoice_data['post_type'] = 'wpi_invoice'; |
| 53 | 53 | } |
| 54 | 54 | |
| 55 | - if ( empty( $invoice_data['ip'] ) ) { |
|
| 55 | + if (empty($invoice_data['ip'])) { |
|
| 56 | 56 | $invoice_data['ip'] = wpinv_get_ip(); |
| 57 | 57 | } |
| 58 | 58 | |
| 59 | 59 | // default invoice args, note that status is checked for validity in wpinv_create_invoice() |
| 60 | 60 | $default_args = array( |
| 61 | - 'invoice_id' => (int)$invoice_data['invoice_id'], |
|
| 62 | - 'user_id' => (int)$invoice_data['user_id'], |
|
| 61 | + 'invoice_id' => (int) $invoice_data['invoice_id'], |
|
| 62 | + 'user_id' => (int) $invoice_data['user_id'], |
|
| 63 | 63 | 'status' => $invoice_data['status'], |
| 64 | 64 | 'post_type' => $invoice_data['post_type'], |
| 65 | 65 | ); |
| 66 | 66 | |
| 67 | - $invoice = wpinv_create_invoice( $default_args, $invoice_data, true ); |
|
| 68 | - if ( is_wp_error( $invoice ) ) { |
|
| 67 | + $invoice = wpinv_create_invoice($default_args, $invoice_data, true); |
|
| 68 | + if (is_wp_error($invoice)) { |
|
| 69 | 69 | return $wp_error ? $invoice : 0; |
| 70 | 70 | } |
| 71 | 71 | |
| 72 | - if ( empty( $invoice_data['invoice_id'] ) ) { |
|
| 72 | + if (empty($invoice_data['invoice_id'])) { |
|
| 73 | 73 | //$invoice->add_note( wp_sprintf( __( 'Invoice is created with status %s.', 'invoicing' ), wpinv_status_nicename( $invoice->status ) ) ); |
| 74 | 74 | } |
| 75 | 75 | |
@@ -92,24 +92,24 @@ discard block |
||
| 92 | 92 | 'discount' => array(), |
| 93 | 93 | ); |
| 94 | 94 | |
| 95 | - if ( $user_id = (int)$invoice->get_user_id() ) { |
|
| 96 | - if ( $user_address = wpinv_get_user_address( $user_id ) ) { |
|
| 97 | - $default_user_info = wp_parse_args( $user_address, $default_user_info ); |
|
| 95 | + if ($user_id = (int) $invoice->get_user_id()) { |
|
| 96 | + if ($user_address = wpinv_get_user_address($user_id)) { |
|
| 97 | + $default_user_info = wp_parse_args($user_address, $default_user_info); |
|
| 98 | 98 | } |
| 99 | 99 | } |
| 100 | 100 | |
| 101 | - if ( empty( $invoice_data['user_info'] ) ) { |
|
| 101 | + if (empty($invoice_data['user_info'])) { |
|
| 102 | 102 | $invoice_data['user_info'] = array(); |
| 103 | 103 | } |
| 104 | 104 | |
| 105 | - $user_info = wp_parse_args( $invoice_data['user_info'], $default_user_info ); |
|
| 105 | + $user_info = wp_parse_args($invoice_data['user_info'], $default_user_info); |
|
| 106 | 106 | |
| 107 | - if ( empty( $user_info['first_name'] ) ) { |
|
| 107 | + if (empty($user_info['first_name'])) { |
|
| 108 | 108 | $user_info['first_name'] = $default_user_info['first_name']; |
| 109 | 109 | $user_info['last_name'] = $default_user_info['last_name']; |
| 110 | 110 | } |
| 111 | 111 | |
| 112 | - if ( empty( $user_info['country'] ) ) { |
|
| 112 | + if (empty($user_info['country'])) { |
|
| 113 | 113 | $user_info['country'] = $default_user_info['country']; |
| 114 | 114 | $user_info['state'] = $default_user_info['state']; |
| 115 | 115 | $user_info['city'] = $default_user_info['city']; |
@@ -118,13 +118,13 @@ discard block |
||
| 118 | 118 | $user_info['phone'] = $default_user_info['phone']; |
| 119 | 119 | } |
| 120 | 120 | |
| 121 | - if ( !empty( $user_info['discount'] ) && !is_array( $user_info['discount'] ) ) { |
|
| 122 | - $user_info['discount'] = (array)$user_info['discount']; |
|
| 121 | + if (!empty($user_info['discount']) && !is_array($user_info['discount'])) { |
|
| 122 | + $user_info['discount'] = (array) $user_info['discount']; |
|
| 123 | 123 | } |
| 124 | 124 | |
| 125 | 125 | // Payment details |
| 126 | 126 | $payment_details = array(); |
| 127 | - if ( !empty( $invoice_data['payment_details'] ) ) { |
|
| 127 | + if (!empty($invoice_data['payment_details'])) { |
|
| 128 | 128 | $default_payment_details = array( |
| 129 | 129 | 'gateway' => 'manual', |
| 130 | 130 | 'gateway_title' => '', |
@@ -132,56 +132,56 @@ discard block |
||
| 132 | 132 | 'transaction_id' => '', |
| 133 | 133 | ); |
| 134 | 134 | |
| 135 | - $payment_details = wp_parse_args( $invoice_data['payment_details'], $default_payment_details ); |
|
| 135 | + $payment_details = wp_parse_args($invoice_data['payment_details'], $default_payment_details); |
|
| 136 | 136 | |
| 137 | - if ( empty( $payment_details['gateway'] ) ) { |
|
| 137 | + if (empty($payment_details['gateway'])) { |
|
| 138 | 138 | $payment_details['gateway'] = 'manual'; |
| 139 | 139 | } |
| 140 | 140 | |
| 141 | - if ( empty( $payment_details['currency'] ) ) { |
|
| 141 | + if (empty($payment_details['currency'])) { |
|
| 142 | 142 | $payment_details['currency'] = wpinv_get_default_country(); |
| 143 | 143 | } |
| 144 | 144 | |
| 145 | - if ( empty( $payment_details['gateway_title'] ) ) { |
|
| 146 | - $payment_details['gateway_title'] = wpinv_get_gateway_checkout_label( $payment_details['gateway'] ); |
|
| 145 | + if (empty($payment_details['gateway_title'])) { |
|
| 146 | + $payment_details['gateway_title'] = wpinv_get_gateway_checkout_label($payment_details['gateway']); |
|
| 147 | 147 | } |
| 148 | 148 | } |
| 149 | 149 | |
| 150 | - $invoice->set( 'status', ( !empty( $invoice_data['status'] ) ? $invoice_data['status'] : 'wpi-pending' ) ); |
|
| 151 | - |
|
| 152 | - if ( !empty( $payment_details ) ) { |
|
| 153 | - $invoice->set( 'currency', $payment_details['currency'] ); |
|
| 154 | - $invoice->set( 'gateway', $payment_details['gateway'] ); |
|
| 155 | - $invoice->set( 'gateway_title', $payment_details['gateway_title'] ); |
|
| 156 | - $invoice->set( 'transaction_id', $payment_details['transaction_id'] ); |
|
| 157 | - } |
|
| 158 | - |
|
| 159 | - $invoice->set( 'user_info', $user_info ); |
|
| 160 | - $invoice->set( 'first_name', $user_info['first_name'] ); |
|
| 161 | - $invoice->set( 'last_name', $user_info['last_name'] ); |
|
| 162 | - $invoice->set( 'address', $user_info['address'] ); |
|
| 163 | - $invoice->set( 'company', $user_info['company'] ); |
|
| 164 | - $invoice->set( 'vat_number', $user_info['vat_number'] ); |
|
| 165 | - $invoice->set( 'phone', $user_info['phone'] ); |
|
| 166 | - $invoice->set( 'city', $user_info['city'] ); |
|
| 167 | - $invoice->set( 'country', $user_info['country'] ); |
|
| 168 | - $invoice->set( 'state', $user_info['state'] ); |
|
| 169 | - $invoice->set( 'zip', $user_info['zip'] ); |
|
| 170 | - $invoice->set( 'discounts', $user_info['discount'] ); |
|
| 171 | - $invoice->set( 'ip', ( !empty( $invoice_data['ip'] ) ? $invoice_data['ip'] : wpinv_get_ip() ) ); |
|
| 172 | - $invoice->set( 'mode', ( wpinv_is_test_mode() ? 'test' : 'live' ) ); |
|
| 173 | - $invoice->set( 'parent_invoice', ( !empty( $invoice_data['parent'] ) ? absint( $invoice_data['parent'] ) : '' ) ); |
|
| 174 | - |
|
| 175 | - if ( !empty( $invoice_data['cart_details'] ) && is_array( $invoice_data['cart_details'] ) ) { |
|
| 176 | - foreach ( $invoice_data['cart_details'] as $key => $item ) { |
|
| 177 | - $item_id = !empty( $item['id'] ) ? $item['id'] : 0; |
|
| 178 | - $quantity = !empty( $item['quantity'] ) ? $item['quantity'] : 1; |
|
| 179 | - $name = !empty( $item['name'] ) ? $item['name'] : ''; |
|
| 180 | - $item_price = isset( $item['item_price'] ) ? $item['item_price'] : ''; |
|
| 150 | + $invoice->set('status', (!empty($invoice_data['status']) ? $invoice_data['status'] : 'wpi-pending')); |
|
| 151 | + |
|
| 152 | + if (!empty($payment_details)) { |
|
| 153 | + $invoice->set('currency', $payment_details['currency']); |
|
| 154 | + $invoice->set('gateway', $payment_details['gateway']); |
|
| 155 | + $invoice->set('gateway_title', $payment_details['gateway_title']); |
|
| 156 | + $invoice->set('transaction_id', $payment_details['transaction_id']); |
|
| 157 | + } |
|
| 158 | + |
|
| 159 | + $invoice->set('user_info', $user_info); |
|
| 160 | + $invoice->set('first_name', $user_info['first_name']); |
|
| 161 | + $invoice->set('last_name', $user_info['last_name']); |
|
| 162 | + $invoice->set('address', $user_info['address']); |
|
| 163 | + $invoice->set('company', $user_info['company']); |
|
| 164 | + $invoice->set('vat_number', $user_info['vat_number']); |
|
| 165 | + $invoice->set('phone', $user_info['phone']); |
|
| 166 | + $invoice->set('city', $user_info['city']); |
|
| 167 | + $invoice->set('country', $user_info['country']); |
|
| 168 | + $invoice->set('state', $user_info['state']); |
|
| 169 | + $invoice->set('zip', $user_info['zip']); |
|
| 170 | + $invoice->set('discounts', $user_info['discount']); |
|
| 171 | + $invoice->set('ip', (!empty($invoice_data['ip']) ? $invoice_data['ip'] : wpinv_get_ip())); |
|
| 172 | + $invoice->set('mode', (wpinv_is_test_mode() ? 'test' : 'live')); |
|
| 173 | + $invoice->set('parent_invoice', (!empty($invoice_data['parent']) ? absint($invoice_data['parent']) : '')); |
|
| 174 | + |
|
| 175 | + if (!empty($invoice_data['cart_details']) && is_array($invoice_data['cart_details'])) { |
|
| 176 | + foreach ($invoice_data['cart_details'] as $key => $item) { |
|
| 177 | + $item_id = !empty($item['id']) ? $item['id'] : 0; |
|
| 178 | + $quantity = !empty($item['quantity']) ? $item['quantity'] : 1; |
|
| 179 | + $name = !empty($item['name']) ? $item['name'] : ''; |
|
| 180 | + $item_price = isset($item['item_price']) ? $item['item_price'] : ''; |
|
| 181 | 181 | |
| 182 | - $post_item = new WPInv_Item( $item_id ); |
|
| 183 | - if ( !empty( $post_item ) ) { |
|
| 184 | - $name = !empty( $name ) ? $name : $post_item->get_name(); |
|
| 182 | + $post_item = new WPInv_Item($item_id); |
|
| 183 | + if (!empty($post_item)) { |
|
| 184 | + $name = !empty($name) ? $name : $post_item->get_name(); |
|
| 185 | 185 | $item_price = $item_price !== '' ? $item_price : $post_item->get_price(); |
| 186 | 186 | } else { |
| 187 | 187 | continue; |
@@ -191,262 +191,262 @@ discard block |
||
| 191 | 191 | 'name' => $name, |
| 192 | 192 | 'quantity' => $quantity, |
| 193 | 193 | 'item_price' => $item_price, |
| 194 | - 'custom_price' => isset( $item['custom_price'] ) ? $item['custom_price'] : '', |
|
| 195 | - 'tax' => !empty( $item['tax'] ) ? $item['tax'] : 0.00, |
|
| 196 | - 'discount' => isset( $item['discount'] ) ? $item['discount'] : 0, |
|
| 197 | - 'meta' => isset( $item['meta'] ) ? $item['meta'] : array(), |
|
| 198 | - 'fees' => isset( $item['fees'] ) ? $item['fees'] : array(), |
|
| 194 | + 'custom_price' => isset($item['custom_price']) ? $item['custom_price'] : '', |
|
| 195 | + 'tax' => !empty($item['tax']) ? $item['tax'] : 0.00, |
|
| 196 | + 'discount' => isset($item['discount']) ? $item['discount'] : 0, |
|
| 197 | + 'meta' => isset($item['meta']) ? $item['meta'] : array(), |
|
| 198 | + 'fees' => isset($item['fees']) ? $item['fees'] : array(), |
|
| 199 | 199 | ); |
| 200 | 200 | |
| 201 | - $invoice->add_item( $item_id, $args ); |
|
| 201 | + $invoice->add_item($item_id, $args); |
|
| 202 | 202 | } |
| 203 | 203 | } |
| 204 | 204 | |
| 205 | - $invoice->increase_tax( wpinv_get_cart_fee_tax() ); |
|
| 205 | + $invoice->increase_tax(wpinv_get_cart_fee_tax()); |
|
| 206 | 206 | |
| 207 | - if ( isset( $invoice_data['post_date'] ) ) { |
|
| 208 | - $invoice->set( 'date', $invoice_data['post_date'] ); |
|
| 207 | + if (isset($invoice_data['post_date'])) { |
|
| 208 | + $invoice->set('date', $invoice_data['post_date']); |
|
| 209 | 209 | } |
| 210 | 210 | |
| 211 | 211 | // Invoice due date |
| 212 | - if ( isset( $invoice_data['due_date'] ) ) { |
|
| 213 | - $invoice->set( 'due_date', $invoice_data['due_date'] ); |
|
| 212 | + if (isset($invoice_data['due_date'])) { |
|
| 213 | + $invoice->set('due_date', $invoice_data['due_date']); |
|
| 214 | 214 | } |
| 215 | 215 | |
| 216 | 216 | $invoice->save(); |
| 217 | 217 | |
| 218 | 218 | // Add notes |
| 219 | - if ( !empty( $invoice_data['private_note'] ) ) { |
|
| 220 | - $invoice->add_note( $invoice_data['private_note'] ); |
|
| 219 | + if (!empty($invoice_data['private_note'])) { |
|
| 220 | + $invoice->add_note($invoice_data['private_note']); |
|
| 221 | 221 | } |
| 222 | - if ( !empty( $invoice_data['user_note'] ) ) { |
|
| 223 | - $invoice->add_note( $invoice_data['user_note'], true ); |
|
| 222 | + if (!empty($invoice_data['user_note'])) { |
|
| 223 | + $invoice->add_note($invoice_data['user_note'], true); |
|
| 224 | 224 | } |
| 225 | 225 | |
| 226 | - if ( $invoice->is_quote() ) { |
|
| 226 | + if ($invoice->is_quote()) { |
|
| 227 | 227 | |
| 228 | - if ( isset( $invoice_data['valid_until'] ) ) { |
|
| 229 | - update_post_meta( $invoice->ID, 'wpinv_quote_valid_until', $invoice_data['valid_until'] ); |
|
| 228 | + if (isset($invoice_data['valid_until'])) { |
|
| 229 | + update_post_meta($invoice->ID, 'wpinv_quote_valid_until', $invoice_data['valid_until']); |
|
| 230 | 230 | } |
| 231 | 231 | return $invoice; |
| 232 | 232 | |
| 233 | 233 | } |
| 234 | 234 | |
| 235 | - do_action( 'wpinv_insert_invoice', $invoice->ID, $invoice_data ); |
|
| 235 | + do_action('wpinv_insert_invoice', $invoice->ID, $invoice_data); |
|
| 236 | 236 | |
| 237 | - if ( ! empty( $invoice->ID ) ) { |
|
| 237 | + if (!empty($invoice->ID)) { |
|
| 238 | 238 | global $wpi_userID, $wpinv_ip_address_country; |
| 239 | 239 | |
| 240 | 240 | $checkout_session = wpinv_get_checkout_session(); |
| 241 | 241 | |
| 242 | 242 | $data_session = array(); |
| 243 | 243 | $data_session['invoice_id'] = $invoice->ID; |
| 244 | - $data_session['cart_discounts'] = $invoice->get_discounts( true ); |
|
| 244 | + $data_session['cart_discounts'] = $invoice->get_discounts(true); |
|
| 245 | 245 | |
| 246 | - wpinv_set_checkout_session( $data_session ); |
|
| 246 | + wpinv_set_checkout_session($data_session); |
|
| 247 | 247 | |
| 248 | - $wpi_userID = (int)$invoice->get_user_id(); |
|
| 248 | + $wpi_userID = (int) $invoice->get_user_id(); |
|
| 249 | 249 | |
| 250 | - $_POST['country'] = !empty( $invoice->country ) ? $invoice->country : wpinv_get_default_country(); |
|
| 250 | + $_POST['country'] = !empty($invoice->country) ? $invoice->country : wpinv_get_default_country(); |
|
| 251 | 251 | $_POST['state'] = $invoice->state; |
| 252 | 252 | |
| 253 | - $invoice->set( 'country', sanitize_text_field( $_POST['country'] ) ); |
|
| 254 | - $invoice->set( 'state', sanitize_text_field( $_POST['state'] ) ); |
|
| 253 | + $invoice->set('country', sanitize_text_field($_POST['country'])); |
|
| 254 | + $invoice->set('state', sanitize_text_field($_POST['state'])); |
|
| 255 | 255 | |
| 256 | 256 | $wpinv_ip_address_country = $invoice->country; |
| 257 | 257 | |
| 258 | - $invoice = $invoice->recalculate_totals( true ); |
|
| 258 | + $invoice = $invoice->recalculate_totals(true); |
|
| 259 | 259 | |
| 260 | - wpinv_set_checkout_session( $checkout_session ); |
|
| 260 | + wpinv_set_checkout_session($checkout_session); |
|
| 261 | 261 | |
| 262 | 262 | return $invoice; |
| 263 | 263 | } |
| 264 | 264 | |
| 265 | - if ( $wp_error ) { |
|
| 266 | - if ( is_wp_error( $invoice ) ) { |
|
| 265 | + if ($wp_error) { |
|
| 266 | + if (is_wp_error($invoice)) { |
|
| 267 | 267 | return $invoice; |
| 268 | 268 | } else { |
| 269 | - return new WP_Error( 'wpinv_insert_invoice_error', __( 'Error in insert invoice.', 'invoicing' ) ); |
|
| 269 | + return new WP_Error('wpinv_insert_invoice_error', __('Error in insert invoice.', 'invoicing')); |
|
| 270 | 270 | } |
| 271 | 271 | } else { |
| 272 | 272 | return 0; |
| 273 | 273 | } |
| 274 | 274 | } |
| 275 | 275 | |
| 276 | -function wpinv_update_invoice( $invoice_data = array(), $wp_error = false ) { |
|
| 277 | - $invoice_ID = !empty( $invoice_data['ID'] ) ? absint( $invoice_data['ID'] ) : NULL; |
|
| 276 | +function wpinv_update_invoice($invoice_data = array(), $wp_error = false) { |
|
| 277 | + $invoice_ID = !empty($invoice_data['ID']) ? absint($invoice_data['ID']) : NULL; |
|
| 278 | 278 | |
| 279 | - if ( !$invoice_ID ) { |
|
| 280 | - if ( $wp_error ) { |
|
| 281 | - return new WP_Error( 'invalid_invoice_id', __( 'Invalid invoice ID.', 'invoicing' ) ); |
|
| 279 | + if (!$invoice_ID) { |
|
| 280 | + if ($wp_error) { |
|
| 281 | + return new WP_Error('invalid_invoice_id', __('Invalid invoice ID.', 'invoicing')); |
|
| 282 | 282 | } |
| 283 | 283 | return 0; |
| 284 | 284 | } |
| 285 | 285 | |
| 286 | - $invoice = wpinv_get_invoice( $invoice_ID ); |
|
| 286 | + $invoice = wpinv_get_invoice($invoice_ID); |
|
| 287 | 287 | |
| 288 | - $recurring_item = $invoice->is_recurring() ? $invoice->get_recurring( true ) : NULL; |
|
| 288 | + $recurring_item = $invoice->is_recurring() ? $invoice->get_recurring(true) : NULL; |
|
| 289 | 289 | |
| 290 | - if ( empty( $invoice->ID ) ) { |
|
| 291 | - if ( $wp_error ) { |
|
| 292 | - return new WP_Error( 'invalid_invoice', __( 'Invalid invoice.', 'invoicing' ) ); |
|
| 290 | + if (empty($invoice->ID)) { |
|
| 291 | + if ($wp_error) { |
|
| 292 | + return new WP_Error('invalid_invoice', __('Invalid invoice.', 'invoicing')); |
|
| 293 | 293 | } |
| 294 | 294 | return 0; |
| 295 | 295 | } |
| 296 | 296 | |
| 297 | - if ( ! $invoice->has_status( array( 'wpi-pending' ) ) && ! $invoice->is_quote() ) { |
|
| 298 | - if ( $wp_error ) { |
|
| 299 | - return new WP_Error( 'invalid_invoice_status', __( 'Only invoice with pending payment is allowed to update.', 'invoicing' ) ); |
|
| 297 | + if (!$invoice->has_status(array('wpi-pending')) && !$invoice->is_quote()) { |
|
| 298 | + if ($wp_error) { |
|
| 299 | + return new WP_Error('invalid_invoice_status', __('Only invoice with pending payment is allowed to update.', 'invoicing')); |
|
| 300 | 300 | } |
| 301 | 301 | return 0; |
| 302 | 302 | } |
| 303 | 303 | |
| 304 | 304 | // Invoice status |
| 305 | - if ( !empty( $invoice_data['status'] ) ) { |
|
| 306 | - $invoice->set( 'status', $invoice_data['status'] ); |
|
| 305 | + if (!empty($invoice_data['status'])) { |
|
| 306 | + $invoice->set('status', $invoice_data['status']); |
|
| 307 | 307 | } |
| 308 | 308 | |
| 309 | 309 | // Invoice date |
| 310 | - if ( !empty( $invoice_data['post_date'] ) ) { |
|
| 311 | - $invoice->set( 'date', $invoice_data['post_date'] ); |
|
| 310 | + if (!empty($invoice_data['post_date'])) { |
|
| 311 | + $invoice->set('date', $invoice_data['post_date']); |
|
| 312 | 312 | } |
| 313 | 313 | |
| 314 | 314 | // Invoice due date |
| 315 | - if ( isset( $invoice_data['due_date'] ) ) { |
|
| 316 | - $invoice->set( 'due_date', $invoice_data['due_date'] ); |
|
| 315 | + if (isset($invoice_data['due_date'])) { |
|
| 316 | + $invoice->set('due_date', $invoice_data['due_date']); |
|
| 317 | 317 | } |
| 318 | 318 | |
| 319 | 319 | // Invoice IP address |
| 320 | - if ( !empty( $invoice_data['ip'] ) ) { |
|
| 321 | - $invoice->set( 'ip', $invoice_data['ip'] ); |
|
| 320 | + if (!empty($invoice_data['ip'])) { |
|
| 321 | + $invoice->set('ip', $invoice_data['ip']); |
|
| 322 | 322 | } |
| 323 | 323 | |
| 324 | 324 | // User info |
| 325 | - if ( !empty( $invoice_data['user_info'] ) && is_array( $invoice_data['user_info'] ) ) { |
|
| 326 | - $user_info = wp_parse_args( $invoice_data['user_info'], $invoice->user_info ); |
|
| 325 | + if (!empty($invoice_data['user_info']) && is_array($invoice_data['user_info'])) { |
|
| 326 | + $user_info = wp_parse_args($invoice_data['user_info'], $invoice->user_info); |
|
| 327 | 327 | |
| 328 | - if ( $discounts = $invoice->get_discounts() ) { |
|
| 328 | + if ($discounts = $invoice->get_discounts()) { |
|
| 329 | 329 | $set_discount = $discounts; |
| 330 | 330 | } else { |
| 331 | 331 | $set_discount = ''; |
| 332 | 332 | } |
| 333 | 333 | |
| 334 | 334 | // Manage discount |
| 335 | - if ( !empty( $invoice_data['user_info']['discount'] ) ) { |
|
| 335 | + if (!empty($invoice_data['user_info']['discount'])) { |
|
| 336 | 336 | // Remove discount |
| 337 | - if ( $invoice_data['user_info']['discount'] == 'none' ) { |
|
| 337 | + if ($invoice_data['user_info']['discount'] == 'none') { |
|
| 338 | 338 | $set_discount = ''; |
| 339 | 339 | } else { |
| 340 | 340 | $set_discount = $invoice_data['user_info']['discount']; |
| 341 | 341 | } |
| 342 | 342 | |
| 343 | - $invoice->set( 'discounts', $set_discount ); |
|
| 343 | + $invoice->set('discounts', $set_discount); |
|
| 344 | 344 | } |
| 345 | 345 | |
| 346 | 346 | $user_info['discount'] = $set_discount; |
| 347 | 347 | |
| 348 | - $invoice->set( 'user_info', $user_info ); |
|
| 348 | + $invoice->set('user_info', $user_info); |
|
| 349 | 349 | } |
| 350 | 350 | |
| 351 | - if ( !empty( $invoice_data['cart_details'] ) && is_array( $invoice_data['cart_details'] ) && $cart_details = $invoice_data['cart_details'] ) { |
|
| 352 | - $remove_items = !empty( $cart_details['remove_items'] ) && is_array( $cart_details['remove_items'] ) ? $cart_details['remove_items'] : array(); |
|
| 351 | + if (!empty($invoice_data['cart_details']) && is_array($invoice_data['cart_details']) && $cart_details = $invoice_data['cart_details']) { |
|
| 352 | + $remove_items = !empty($cart_details['remove_items']) && is_array($cart_details['remove_items']) ? $cart_details['remove_items'] : array(); |
|
| 353 | 353 | |
| 354 | - if ( !empty( $remove_items[0]['id'] ) ) { |
|
| 355 | - foreach ( $remove_items as $item ) { |
|
| 356 | - $item_id = !empty( $item['id'] ) ? $item['id'] : 0; |
|
| 357 | - $quantity = !empty( $item['quantity'] ) ? $item['quantity'] : 1; |
|
| 358 | - if ( empty( $item_id ) ) { |
|
| 354 | + if (!empty($remove_items[0]['id'])) { |
|
| 355 | + foreach ($remove_items as $item) { |
|
| 356 | + $item_id = !empty($item['id']) ? $item['id'] : 0; |
|
| 357 | + $quantity = !empty($item['quantity']) ? $item['quantity'] : 1; |
|
| 358 | + if (empty($item_id)) { |
|
| 359 | 359 | continue; |
| 360 | 360 | } |
| 361 | 361 | |
| 362 | - foreach ( $invoice->cart_details as $cart_index => $cart_item ) { |
|
| 363 | - if ( $item_id == $cart_item['id'] ) { |
|
| 362 | + foreach ($invoice->cart_details as $cart_index => $cart_item) { |
|
| 363 | + if ($item_id == $cart_item['id']) { |
|
| 364 | 364 | $args = array( |
| 365 | 365 | 'id' => $item_id, |
| 366 | 366 | 'quantity' => $quantity, |
| 367 | 367 | 'cart_index' => $cart_index |
| 368 | 368 | ); |
| 369 | 369 | |
| 370 | - $invoice->remove_item( $item_id, $args ); |
|
| 370 | + $invoice->remove_item($item_id, $args); |
|
| 371 | 371 | break; |
| 372 | 372 | } |
| 373 | 373 | } |
| 374 | 374 | } |
| 375 | 375 | } |
| 376 | 376 | |
| 377 | - $add_items = !empty( $cart_details['add_items'] ) && is_array( $cart_details['add_items'] ) ? $cart_details['add_items'] : array(); |
|
| 377 | + $add_items = !empty($cart_details['add_items']) && is_array($cart_details['add_items']) ? $cart_details['add_items'] : array(); |
|
| 378 | 378 | |
| 379 | - if ( !empty( $add_items[0]['id'] ) ) { |
|
| 380 | - foreach ( $add_items as $item ) { |
|
| 381 | - $item_id = !empty( $item['id'] ) ? $item['id'] : 0; |
|
| 382 | - $post_item = new WPInv_Item( $item_id ); |
|
| 383 | - if ( empty( $post_item ) ) { |
|
| 379 | + if (!empty($add_items[0]['id'])) { |
|
| 380 | + foreach ($add_items as $item) { |
|
| 381 | + $item_id = !empty($item['id']) ? $item['id'] : 0; |
|
| 382 | + $post_item = new WPInv_Item($item_id); |
|
| 383 | + if (empty($post_item)) { |
|
| 384 | 384 | continue; |
| 385 | 385 | } |
| 386 | 386 | |
| 387 | 387 | $valid_item = true; |
| 388 | - if ( !empty( $recurring_item ) ) { |
|
| 389 | - if ( $recurring_item->ID != $item_id ) { |
|
| 388 | + if (!empty($recurring_item)) { |
|
| 389 | + if ($recurring_item->ID != $item_id) { |
|
| 390 | 390 | $valid_item = false; |
| 391 | 391 | } |
| 392 | - } else if ( wpinv_is_recurring_item( $item_id ) ) { |
|
| 392 | + } else if (wpinv_is_recurring_item($item_id)) { |
|
| 393 | 393 | $valid_item = false; |
| 394 | 394 | } |
| 395 | 395 | |
| 396 | - if ( !$valid_item ) { |
|
| 397 | - if ( $wp_error ) { |
|
| 398 | - return new WP_Error( 'invalid_invoice_item', __( 'You can not add item because recurring item must be paid individually!', 'invoicing' ) ); |
|
| 396 | + if (!$valid_item) { |
|
| 397 | + if ($wp_error) { |
|
| 398 | + return new WP_Error('invalid_invoice_item', __('You can not add item because recurring item must be paid individually!', 'invoicing')); |
|
| 399 | 399 | } |
| 400 | 400 | return 0; |
| 401 | 401 | } |
| 402 | 402 | |
| 403 | - $quantity = !empty( $item['quantity'] ) ? $item['quantity'] : 1; |
|
| 404 | - $name = !empty( $item['name'] ) ? $item['name'] : $post_item->get_name(); |
|
| 405 | - $item_price = isset( $item['item_price'] ) ? $item['item_price'] : $post_item->get_price(); |
|
| 403 | + $quantity = !empty($item['quantity']) ? $item['quantity'] : 1; |
|
| 404 | + $name = !empty($item['name']) ? $item['name'] : $post_item->get_name(); |
|
| 405 | + $item_price = isset($item['item_price']) ? $item['item_price'] : $post_item->get_price(); |
|
| 406 | 406 | |
| 407 | 407 | $args = array( |
| 408 | 408 | 'name' => $name, |
| 409 | 409 | 'quantity' => $quantity, |
| 410 | 410 | 'item_price' => $item_price, |
| 411 | - 'custom_price' => isset( $item['custom_price'] ) ? $item['custom_price'] : '', |
|
| 412 | - 'tax' => !empty( $item['tax'] ) ? $item['tax'] : 0, |
|
| 413 | - 'discount' => isset( $item['discount'] ) ? $item['discount'] : 0, |
|
| 414 | - 'meta' => isset( $item['meta'] ) ? $item['meta'] : array(), |
|
| 415 | - 'fees' => isset( $item['fees'] ) ? $item['fees'] : array(), |
|
| 411 | + 'custom_price' => isset($item['custom_price']) ? $item['custom_price'] : '', |
|
| 412 | + 'tax' => !empty($item['tax']) ? $item['tax'] : 0, |
|
| 413 | + 'discount' => isset($item['discount']) ? $item['discount'] : 0, |
|
| 414 | + 'meta' => isset($item['meta']) ? $item['meta'] : array(), |
|
| 415 | + 'fees' => isset($item['fees']) ? $item['fees'] : array(), |
|
| 416 | 416 | ); |
| 417 | 417 | |
| 418 | - $invoice->add_item( $item_id, $args ); |
|
| 418 | + $invoice->add_item($item_id, $args); |
|
| 419 | 419 | } |
| 420 | 420 | } |
| 421 | 421 | } |
| 422 | 422 | |
| 423 | 423 | // Payment details |
| 424 | - if ( !empty( $invoice_data['payment_details'] ) && $payment_details = $invoice_data['payment_details'] ) { |
|
| 425 | - if ( !empty( $payment_details['gateway'] ) ) { |
|
| 426 | - $invoice->set( 'gateway', $payment_details['gateway'] ); |
|
| 424 | + if (!empty($invoice_data['payment_details']) && $payment_details = $invoice_data['payment_details']) { |
|
| 425 | + if (!empty($payment_details['gateway'])) { |
|
| 426 | + $invoice->set('gateway', $payment_details['gateway']); |
|
| 427 | 427 | } |
| 428 | 428 | |
| 429 | - if ( !empty( $payment_details['transaction_id'] ) ) { |
|
| 430 | - $invoice->set( 'transaction_id', $payment_details['transaction_id'] ); |
|
| 429 | + if (!empty($payment_details['transaction_id'])) { |
|
| 430 | + $invoice->set('transaction_id', $payment_details['transaction_id']); |
|
| 431 | 431 | } |
| 432 | 432 | } |
| 433 | 433 | |
| 434 | - do_action( 'wpinv_pre_update_invoice', $invoice->ID, $invoice_data ); |
|
| 434 | + do_action('wpinv_pre_update_invoice', $invoice->ID, $invoice_data); |
|
| 435 | 435 | |
| 436 | 436 | // Parent invoice |
| 437 | - if ( !empty( $invoice_data['parent'] ) ) { |
|
| 438 | - $invoice->set( 'parent_invoice', $invoice_data['parent'] ); |
|
| 437 | + if (!empty($invoice_data['parent'])) { |
|
| 438 | + $invoice->set('parent_invoice', $invoice_data['parent']); |
|
| 439 | 439 | } |
| 440 | 440 | |
| 441 | 441 | // Save invoice data. |
| 442 | 442 | $invoice->save(); |
| 443 | 443 | |
| 444 | - if ( empty( $invoice->ID ) || is_wp_error( $invoice ) ) { |
|
| 445 | - if ( $wp_error ) { |
|
| 446 | - if ( is_wp_error( $invoice ) ) { |
|
| 444 | + if (empty($invoice->ID) || is_wp_error($invoice)) { |
|
| 445 | + if ($wp_error) { |
|
| 446 | + if (is_wp_error($invoice)) { |
|
| 447 | 447 | return $invoice; |
| 448 | 448 | } else { |
| 449 | - return new WP_Error( 'wpinv_update_invoice_error', __( 'Error in update invoice.', 'invoicing' ) ); |
|
| 449 | + return new WP_Error('wpinv_update_invoice_error', __('Error in update invoice.', 'invoicing')); |
|
| 450 | 450 | } |
| 451 | 451 | } else { |
| 452 | 452 | return 0; |
@@ -454,19 +454,19 @@ discard block |
||
| 454 | 454 | } |
| 455 | 455 | |
| 456 | 456 | // Add private note |
| 457 | - if ( !empty( $invoice_data['private_note'] ) ) { |
|
| 458 | - $invoice->add_note( $invoice_data['private_note'] ); |
|
| 457 | + if (!empty($invoice_data['private_note'])) { |
|
| 458 | + $invoice->add_note($invoice_data['private_note']); |
|
| 459 | 459 | } |
| 460 | 460 | |
| 461 | 461 | // Add user note |
| 462 | - if ( !empty( $invoice_data['user_note'] ) ) { |
|
| 463 | - $invoice->add_note( $invoice_data['user_note'], true ); |
|
| 462 | + if (!empty($invoice_data['user_note'])) { |
|
| 463 | + $invoice->add_note($invoice_data['user_note'], true); |
|
| 464 | 464 | } |
| 465 | 465 | |
| 466 | - if ( $invoice->is_quote() ) { |
|
| 466 | + if ($invoice->is_quote()) { |
|
| 467 | 467 | |
| 468 | - if ( isset( $invoice_data['valid_until'] ) ) { |
|
| 469 | - update_post_meta( $invoice->ID, 'wpinv_quote_valid_until', $invoice_data['valid_until'] ); |
|
| 468 | + if (isset($invoice_data['valid_until'])) { |
|
| 469 | + update_post_meta($invoice->ID, 'wpinv_quote_valid_until', $invoice_data['valid_until']); |
|
| 470 | 470 | } |
| 471 | 471 | return $invoice; |
| 472 | 472 | |
@@ -478,466 +478,466 @@ discard block |
||
| 478 | 478 | |
| 479 | 479 | $data_session = array(); |
| 480 | 480 | $data_session['invoice_id'] = $invoice->ID; |
| 481 | - $data_session['cart_discounts'] = $invoice->get_discounts( true ); |
|
| 481 | + $data_session['cart_discounts'] = $invoice->get_discounts(true); |
|
| 482 | 482 | |
| 483 | - wpinv_set_checkout_session( $data_session ); |
|
| 483 | + wpinv_set_checkout_session($data_session); |
|
| 484 | 484 | |
| 485 | - $wpi_userID = (int)$invoice->get_user_id(); |
|
| 485 | + $wpi_userID = (int) $invoice->get_user_id(); |
|
| 486 | 486 | |
| 487 | - $_POST['country'] = !empty( $invoice->country ) ? $invoice->country : wpinv_get_default_country(); |
|
| 487 | + $_POST['country'] = !empty($invoice->country) ? $invoice->country : wpinv_get_default_country(); |
|
| 488 | 488 | $_POST['state'] = $invoice->state; |
| 489 | 489 | |
| 490 | - $invoice->set( 'country', sanitize_text_field( $_POST['country'] ) ); |
|
| 491 | - $invoice->set( 'state', sanitize_text_field( $_POST['state'] ) ); |
|
| 490 | + $invoice->set('country', sanitize_text_field($_POST['country'])); |
|
| 491 | + $invoice->set('state', sanitize_text_field($_POST['state'])); |
|
| 492 | 492 | |
| 493 | 493 | $wpinv_ip_address_country = $invoice->country; |
| 494 | 494 | |
| 495 | - $invoice = $invoice->recalculate_totals( true ); |
|
| 495 | + $invoice = $invoice->recalculate_totals(true); |
|
| 496 | 496 | |
| 497 | - do_action( 'wpinv_post_update_invoice', $invoice->ID, $invoice_data ); |
|
| 497 | + do_action('wpinv_post_update_invoice', $invoice->ID, $invoice_data); |
|
| 498 | 498 | |
| 499 | - wpinv_set_checkout_session( $checkout_session ); |
|
| 499 | + wpinv_set_checkout_session($checkout_session); |
|
| 500 | 500 | |
| 501 | 501 | return $invoice; |
| 502 | 502 | } |
| 503 | 503 | |
| 504 | -function wpinv_get_invoice( $invoice_id = 0, $cart = false ) { |
|
| 505 | - if ( $cart && empty( $invoice_id ) ) { |
|
| 506 | - $invoice_id = (int)wpinv_get_invoice_cart_id(); |
|
| 504 | +function wpinv_get_invoice($invoice_id = 0, $cart = false) { |
|
| 505 | + if ($cart && empty($invoice_id)) { |
|
| 506 | + $invoice_id = (int) wpinv_get_invoice_cart_id(); |
|
| 507 | 507 | } |
| 508 | 508 | |
| 509 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 509 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 510 | 510 | |
| 511 | - if ( ! empty( $invoice ) && ! empty( $invoice->ID ) ) { |
|
| 511 | + if (!empty($invoice) && !empty($invoice->ID)) { |
|
| 512 | 512 | return $invoice; |
| 513 | 513 | } |
| 514 | 514 | |
| 515 | 515 | return NULL; |
| 516 | 516 | } |
| 517 | 517 | |
| 518 | -function wpinv_get_invoice_cart( $invoice_id = 0 ) { |
|
| 519 | - return wpinv_get_invoice( $invoice_id, true ); |
|
| 518 | +function wpinv_get_invoice_cart($invoice_id = 0) { |
|
| 519 | + return wpinv_get_invoice($invoice_id, true); |
|
| 520 | 520 | } |
| 521 | 521 | |
| 522 | -function wpinv_get_invoice_description( $invoice_id = 0 ) { |
|
| 523 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 522 | +function wpinv_get_invoice_description($invoice_id = 0) { |
|
| 523 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 524 | 524 | return $invoice->get_description(); |
| 525 | 525 | } |
| 526 | 526 | |
| 527 | -function wpinv_get_invoice_currency_code( $invoice_id = 0 ) { |
|
| 528 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 527 | +function wpinv_get_invoice_currency_code($invoice_id = 0) { |
|
| 528 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 529 | 529 | return $invoice->get_currency(); |
| 530 | 530 | } |
| 531 | 531 | |
| 532 | -function wpinv_get_payment_user_email( $invoice_id ) { |
|
| 533 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 532 | +function wpinv_get_payment_user_email($invoice_id) { |
|
| 533 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 534 | 534 | return $invoice->get_email(); |
| 535 | 535 | } |
| 536 | 536 | |
| 537 | -function wpinv_get_user_id( $invoice_id ) { |
|
| 538 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 537 | +function wpinv_get_user_id($invoice_id) { |
|
| 538 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 539 | 539 | return $invoice->get_user_id(); |
| 540 | 540 | } |
| 541 | 541 | |
| 542 | -function wpinv_get_invoice_status( $invoice_id, $return_label = false ) { |
|
| 543 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 542 | +function wpinv_get_invoice_status($invoice_id, $return_label = false) { |
|
| 543 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 544 | 544 | |
| 545 | - return $invoice->get_status( $return_label ); |
|
| 545 | + return $invoice->get_status($return_label); |
|
| 546 | 546 | } |
| 547 | 547 | |
| 548 | -function wpinv_get_payment_gateway( $invoice_id, $return_label = false ) { |
|
| 549 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 548 | +function wpinv_get_payment_gateway($invoice_id, $return_label = false) { |
|
| 549 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 550 | 550 | |
| 551 | - return $invoice->get_gateway( $return_label ); |
|
| 551 | + return $invoice->get_gateway($return_label); |
|
| 552 | 552 | } |
| 553 | 553 | |
| 554 | -function wpinv_get_payment_gateway_name( $invoice_id ) { |
|
| 555 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 554 | +function wpinv_get_payment_gateway_name($invoice_id) { |
|
| 555 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 556 | 556 | |
| 557 | 557 | return $invoice->get_gateway_title(); |
| 558 | 558 | } |
| 559 | 559 | |
| 560 | -function wpinv_get_payment_transaction_id( $invoice_id ) { |
|
| 561 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 560 | +function wpinv_get_payment_transaction_id($invoice_id) { |
|
| 561 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 562 | 562 | |
| 563 | 563 | return $invoice->get_transaction_id(); |
| 564 | 564 | } |
| 565 | 565 | |
| 566 | -function wpinv_get_id_by_transaction_id( $key ) { |
|
| 566 | +function wpinv_get_id_by_transaction_id($key) { |
|
| 567 | 567 | global $wpdb; |
| 568 | 568 | |
| 569 | - $invoice_id = $wpdb->get_var( $wpdb->prepare( "SELECT post_id FROM $wpdb->postmeta WHERE meta_key = '_wpinv_transaction_id' AND meta_value = %s LIMIT 1", $key ) ); |
|
| 569 | + $invoice_id = $wpdb->get_var($wpdb->prepare("SELECT post_id FROM $wpdb->postmeta WHERE meta_key = '_wpinv_transaction_id' AND meta_value = %s LIMIT 1", $key)); |
|
| 570 | 570 | |
| 571 | - if ( $invoice_id != NULL ) |
|
| 571 | + if ($invoice_id != NULL) |
|
| 572 | 572 | return $invoice_id; |
| 573 | 573 | |
| 574 | 574 | return 0; |
| 575 | 575 | } |
| 576 | 576 | |
| 577 | -function wpinv_get_invoice_meta( $invoice_id = 0, $meta_key = '_wpinv_payment_meta', $single = true ) { |
|
| 578 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 577 | +function wpinv_get_invoice_meta($invoice_id = 0, $meta_key = '_wpinv_payment_meta', $single = true) { |
|
| 578 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 579 | 579 | |
| 580 | - return $invoice->get_meta( $meta_key, $single ); |
|
| 580 | + return $invoice->get_meta($meta_key, $single); |
|
| 581 | 581 | } |
| 582 | 582 | |
| 583 | -function wpinv_update_invoice_meta( $invoice_id = 0, $meta_key = '', $meta_value = '', $prev_value = '' ) { |
|
| 584 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 583 | +function wpinv_update_invoice_meta($invoice_id = 0, $meta_key = '', $meta_value = '', $prev_value = '') { |
|
| 584 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 585 | 585 | |
| 586 | - return $invoice->update_meta( $meta_key, $meta_value, $prev_value ); |
|
| 586 | + return $invoice->update_meta($meta_key, $meta_value, $prev_value); |
|
| 587 | 587 | } |
| 588 | 588 | |
| 589 | -function wpinv_get_items( $invoice_id = 0 ) { |
|
| 590 | - $invoice = wpinv_get_invoice( $invoice_id ); |
|
| 589 | +function wpinv_get_items($invoice_id = 0) { |
|
| 590 | + $invoice = wpinv_get_invoice($invoice_id); |
|
| 591 | 591 | |
| 592 | 592 | $items = $invoice->get_items(); |
| 593 | 593 | $invoice_currency = $invoice->get_currency(); |
| 594 | 594 | |
| 595 | - if ( !empty( $items ) && is_array( $items ) ) { |
|
| 596 | - foreach ( $items as $key => $item ) { |
|
| 595 | + if (!empty($items) && is_array($items)) { |
|
| 596 | + foreach ($items as $key => $item) { |
|
| 597 | 597 | $items[$key]['currency'] = $invoice_currency; |
| 598 | 598 | |
| 599 | - if ( !isset( $item['subtotal'] ) ) { |
|
| 599 | + if (!isset($item['subtotal'])) { |
|
| 600 | 600 | $items[$key]['subtotal'] = $items[$key]['amount'] * 1; |
| 601 | 601 | } |
| 602 | 602 | } |
| 603 | 603 | } |
| 604 | 604 | |
| 605 | - return apply_filters( 'wpinv_get_items', $items, $invoice_id ); |
|
| 605 | + return apply_filters('wpinv_get_items', $items, $invoice_id); |
|
| 606 | 606 | } |
| 607 | 607 | |
| 608 | -function wpinv_get_fees( $invoice_id = 0 ) { |
|
| 609 | - $invoice = wpinv_get_invoice( $invoice_id ); |
|
| 608 | +function wpinv_get_fees($invoice_id = 0) { |
|
| 609 | + $invoice = wpinv_get_invoice($invoice_id); |
|
| 610 | 610 | $fees = $invoice->get_fees(); |
| 611 | 611 | |
| 612 | - return apply_filters( 'wpinv_get_fees', $fees, $invoice_id ); |
|
| 612 | + return apply_filters('wpinv_get_fees', $fees, $invoice_id); |
|
| 613 | 613 | } |
| 614 | 614 | |
| 615 | -function wpinv_get_invoice_ip( $invoice_id ) { |
|
| 616 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 615 | +function wpinv_get_invoice_ip($invoice_id) { |
|
| 616 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 617 | 617 | return $invoice->get_ip(); |
| 618 | 618 | } |
| 619 | 619 | |
| 620 | -function wpinv_get_invoice_user_info( $invoice_id ) { |
|
| 621 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 620 | +function wpinv_get_invoice_user_info($invoice_id) { |
|
| 621 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 622 | 622 | return $invoice->get_user_info(); |
| 623 | 623 | } |
| 624 | 624 | |
| 625 | -function wpinv_subtotal( $invoice_id = 0, $currency = false ) { |
|
| 626 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 625 | +function wpinv_subtotal($invoice_id = 0, $currency = false) { |
|
| 626 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 627 | 627 | |
| 628 | - return $invoice->get_subtotal( $currency ); |
|
| 628 | + return $invoice->get_subtotal($currency); |
|
| 629 | 629 | } |
| 630 | 630 | |
| 631 | -function wpinv_tax( $invoice_id = 0, $currency = false ) { |
|
| 632 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 631 | +function wpinv_tax($invoice_id = 0, $currency = false) { |
|
| 632 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 633 | 633 | |
| 634 | - return $invoice->get_tax( $currency ); |
|
| 634 | + return $invoice->get_tax($currency); |
|
| 635 | 635 | } |
| 636 | 636 | |
| 637 | -function wpinv_discount( $invoice_id = 0, $currency = false, $dash = false ) { |
|
| 638 | - $invoice = wpinv_get_invoice( $invoice_id ); |
|
| 637 | +function wpinv_discount($invoice_id = 0, $currency = false, $dash = false) { |
|
| 638 | + $invoice = wpinv_get_invoice($invoice_id); |
|
| 639 | 639 | |
| 640 | - return $invoice->get_discount( $currency, $dash ); |
|
| 640 | + return $invoice->get_discount($currency, $dash); |
|
| 641 | 641 | } |
| 642 | 642 | |
| 643 | -function wpinv_discount_code( $invoice_id = 0 ) { |
|
| 644 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 643 | +function wpinv_discount_code($invoice_id = 0) { |
|
| 644 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 645 | 645 | |
| 646 | 646 | return $invoice->get_discount_code(); |
| 647 | 647 | } |
| 648 | 648 | |
| 649 | -function wpinv_payment_total( $invoice_id = 0, $currency = false ) { |
|
| 650 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 649 | +function wpinv_payment_total($invoice_id = 0, $currency = false) { |
|
| 650 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 651 | 651 | |
| 652 | - return $invoice->get_total( $currency ); |
|
| 652 | + return $invoice->get_total($currency); |
|
| 653 | 653 | } |
| 654 | 654 | |
| 655 | -function wpinv_get_date_created( $invoice_id = 0, $format = '' ) { |
|
| 656 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 655 | +function wpinv_get_date_created($invoice_id = 0, $format = '') { |
|
| 656 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 657 | 657 | |
| 658 | - $format = !empty( $format ) ? $format : get_option( 'date_format' ); |
|
| 658 | + $format = !empty($format) ? $format : get_option('date_format'); |
|
| 659 | 659 | $date_created = $invoice->get_created_date(); |
| 660 | - $date_created = $date_created != '' && $date_created != '0000-00-00 00:00:00' ? date_i18n( $format, strtotime( $date_created ) ) : ''; |
|
| 660 | + $date_created = $date_created != '' && $date_created != '0000-00-00 00:00:00' ? date_i18n($format, strtotime($date_created)) : ''; |
|
| 661 | 661 | |
| 662 | 662 | return $date_created; |
| 663 | 663 | } |
| 664 | 664 | |
| 665 | -function wpinv_get_invoice_date( $invoice_id = 0, $format = '', $default = true ) { |
|
| 666 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 665 | +function wpinv_get_invoice_date($invoice_id = 0, $format = '', $default = true) { |
|
| 666 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 667 | 667 | |
| 668 | - $format = !empty( $format ) ? $format : get_option( 'date_format' ); |
|
| 668 | + $format = !empty($format) ? $format : get_option('date_format'); |
|
| 669 | 669 | $date_completed = $invoice->get_completed_date(); |
| 670 | - $invoice_date = $date_completed != '' && $date_completed != '0000-00-00 00:00:00' ? date_i18n( $format, strtotime( $date_completed ) ) : ''; |
|
| 671 | - if ( $invoice_date == '' && $default ) { |
|
| 672 | - $invoice_date = wpinv_get_date_created( $invoice_id, $format ); |
|
| 670 | + $invoice_date = $date_completed != '' && $date_completed != '0000-00-00 00:00:00' ? date_i18n($format, strtotime($date_completed)) : ''; |
|
| 671 | + if ($invoice_date == '' && $default) { |
|
| 672 | + $invoice_date = wpinv_get_date_created($invoice_id, $format); |
|
| 673 | 673 | } |
| 674 | 674 | |
| 675 | 675 | return $invoice_date; |
| 676 | 676 | } |
| 677 | 677 | |
| 678 | -function wpinv_get_invoice_vat_number( $invoice_id = 0 ) { |
|
| 679 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 678 | +function wpinv_get_invoice_vat_number($invoice_id = 0) { |
|
| 679 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 680 | 680 | |
| 681 | 681 | return $invoice->vat_number; |
| 682 | 682 | } |
| 683 | 683 | |
| 684 | -function wpinv_insert_payment_note( $invoice_id = 0, $note = '', $user_type = false, $added_by_user = false, $system = false ) { |
|
| 685 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 684 | +function wpinv_insert_payment_note($invoice_id = 0, $note = '', $user_type = false, $added_by_user = false, $system = false) { |
|
| 685 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 686 | 686 | |
| 687 | - return $invoice->add_note( $note, $user_type, $added_by_user, $system ); |
|
| 687 | + return $invoice->add_note($note, $user_type, $added_by_user, $system); |
|
| 688 | 688 | } |
| 689 | 689 | |
| 690 | -function wpinv_get_invoice_notes( $invoice_id = 0, $type = '' ) { |
|
| 690 | +function wpinv_get_invoice_notes($invoice_id = 0, $type = '') { |
|
| 691 | 691 | global $invoicing; |
| 692 | 692 | |
| 693 | - if ( empty( $invoice_id ) ) { |
|
| 693 | + if (empty($invoice_id)) { |
|
| 694 | 694 | return NULL; |
| 695 | 695 | } |
| 696 | 696 | |
| 697 | - $notes = $invoicing->notes->get_invoice_notes( $invoice_id, $type ); |
|
| 697 | + $notes = $invoicing->notes->get_invoice_notes($invoice_id, $type); |
|
| 698 | 698 | |
| 699 | - return apply_filters( 'wpinv_invoice_notes', $notes, $invoice_id, $type ); |
|
| 699 | + return apply_filters('wpinv_invoice_notes', $notes, $invoice_id, $type); |
|
| 700 | 700 | } |
| 701 | 701 | |
| 702 | -function wpinv_get_payment_key( $invoice_id = 0 ) { |
|
| 703 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 702 | +function wpinv_get_payment_key($invoice_id = 0) { |
|
| 703 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 704 | 704 | return $invoice->get_key(); |
| 705 | 705 | } |
| 706 | 706 | |
| 707 | -function wpinv_get_invoice_number( $invoice_id = 0 ) { |
|
| 708 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 707 | +function wpinv_get_invoice_number($invoice_id = 0) { |
|
| 708 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 709 | 709 | return $invoice->get_number(); |
| 710 | 710 | } |
| 711 | 711 | |
| 712 | -function wpinv_get_cart_discountable_subtotal( $code_id ) { |
|
| 712 | +function wpinv_get_cart_discountable_subtotal($code_id) { |
|
| 713 | 713 | $cart_items = wpinv_get_cart_content_details(); |
| 714 | 714 | $items = array(); |
| 715 | 715 | |
| 716 | - $excluded_items = wpinv_get_discount_excluded_items( $code_id ); |
|
| 716 | + $excluded_items = wpinv_get_discount_excluded_items($code_id); |
|
| 717 | 717 | |
| 718 | - if( $cart_items ) { |
|
| 718 | + if ($cart_items) { |
|
| 719 | 719 | |
| 720 | - foreach( $cart_items as $item ) { |
|
| 720 | + foreach ($cart_items as $item) { |
|
| 721 | 721 | |
| 722 | - if( ! in_array( $item['id'], $excluded_items ) ) { |
|
| 723 | - $items[] = $item; |
|
| 722 | + if (!in_array($item['id'], $excluded_items)) { |
|
| 723 | + $items[] = $item; |
|
| 724 | 724 | } |
| 725 | 725 | } |
| 726 | 726 | } |
| 727 | 727 | |
| 728 | - $subtotal = wpinv_get_cart_items_subtotal( $items ); |
|
| 728 | + $subtotal = wpinv_get_cart_items_subtotal($items); |
|
| 729 | 729 | |
| 730 | - return apply_filters( 'wpinv_get_cart_discountable_subtotal', $subtotal ); |
|
| 730 | + return apply_filters('wpinv_get_cart_discountable_subtotal', $subtotal); |
|
| 731 | 731 | } |
| 732 | 732 | |
| 733 | -function wpinv_get_cart_items_subtotal( $items ) { |
|
| 733 | +function wpinv_get_cart_items_subtotal($items) { |
|
| 734 | 734 | $subtotal = 0.00; |
| 735 | 735 | |
| 736 | - if ( is_array( $items ) && ! empty( $items ) ) { |
|
| 737 | - $prices = wp_list_pluck( $items, 'subtotal' ); |
|
| 736 | + if (is_array($items) && !empty($items)) { |
|
| 737 | + $prices = wp_list_pluck($items, 'subtotal'); |
|
| 738 | 738 | |
| 739 | - if( is_array( $prices ) ) { |
|
| 740 | - $subtotal = array_sum( $prices ); |
|
| 739 | + if (is_array($prices)) { |
|
| 740 | + $subtotal = array_sum($prices); |
|
| 741 | 741 | } else { |
| 742 | 742 | $subtotal = 0.00; |
| 743 | 743 | } |
| 744 | 744 | |
| 745 | - if( $subtotal < 0 ) { |
|
| 745 | + if ($subtotal < 0) { |
|
| 746 | 746 | $subtotal = 0.00; |
| 747 | 747 | } |
| 748 | 748 | } |
| 749 | 749 | |
| 750 | - return apply_filters( 'wpinv_get_cart_items_subtotal', $subtotal ); |
|
| 750 | + return apply_filters('wpinv_get_cart_items_subtotal', $subtotal); |
|
| 751 | 751 | } |
| 752 | 752 | |
| 753 | -function wpinv_get_cart_subtotal( $items = array() ) { |
|
| 754 | - $items = !empty( $items ) ? $items : wpinv_get_cart_content_details(); |
|
| 755 | - $subtotal = wpinv_get_cart_items_subtotal( $items ); |
|
| 753 | +function wpinv_get_cart_subtotal($items = array()) { |
|
| 754 | + $items = !empty($items) ? $items : wpinv_get_cart_content_details(); |
|
| 755 | + $subtotal = wpinv_get_cart_items_subtotal($items); |
|
| 756 | 756 | |
| 757 | - return apply_filters( 'wpinv_get_cart_subtotal', $subtotal ); |
|
| 757 | + return apply_filters('wpinv_get_cart_subtotal', $subtotal); |
|
| 758 | 758 | } |
| 759 | 759 | |
| 760 | -function wpinv_cart_subtotal( $items = array(), $currency = '' ) { |
|
| 760 | +function wpinv_cart_subtotal($items = array(), $currency = '') { |
|
| 761 | 761 | |
| 762 | - if( empty( $currency ) ) { |
|
| 762 | + if (empty($currency)) { |
|
| 763 | 763 | $currency = wpinv_get_currency(); |
| 764 | 764 | } |
| 765 | 765 | |
| 766 | - $price = wpinv_price( wpinv_format_amount( wpinv_get_cart_subtotal( $items ) ), $currency ); |
|
| 766 | + $price = wpinv_price(wpinv_format_amount(wpinv_get_cart_subtotal($items)), $currency); |
|
| 767 | 767 | |
| 768 | 768 | return $price; |
| 769 | 769 | } |
| 770 | 770 | |
| 771 | -function wpinv_get_cart_total( $items = array(), $discounts = false, $invoice = array() ) { |
|
| 772 | - $subtotal = (float)wpinv_get_cart_subtotal( $items ); |
|
| 773 | - $discounts = (float)wpinv_get_cart_discounted_amount( $items ); |
|
| 774 | - $cart_tax = (float)wpinv_get_cart_tax( $items, $invoice ); |
|
| 775 | - $fees = (float)wpinv_get_cart_fee_total(); |
|
| 776 | - if ( !empty( $invoice ) && $invoice->is_free_trial() ) { |
|
| 771 | +function wpinv_get_cart_total($items = array(), $discounts = false, $invoice = array()) { |
|
| 772 | + $subtotal = (float) wpinv_get_cart_subtotal($items); |
|
| 773 | + $discounts = (float) wpinv_get_cart_discounted_amount($items); |
|
| 774 | + $cart_tax = (float) wpinv_get_cart_tax($items, $invoice); |
|
| 775 | + $fees = (float) wpinv_get_cart_fee_total(); |
|
| 776 | + if (!empty($invoice) && $invoice->is_free_trial()) { |
|
| 777 | 777 | $total = 0; |
| 778 | 778 | } else { |
| 779 | - $total = $subtotal - $discounts + $cart_tax + $fees; |
|
| 779 | + $total = $subtotal - $discounts + $cart_tax + $fees; |
|
| 780 | 780 | } |
| 781 | 781 | |
| 782 | - if ( $total < 0 ) { |
|
| 782 | + if ($total < 0) { |
|
| 783 | 783 | $total = 0.00; |
| 784 | 784 | } |
| 785 | 785 | |
| 786 | - $total = (float)apply_filters( 'wpinv_get_cart_total', $total, $items ); |
|
| 786 | + $total = (float) apply_filters('wpinv_get_cart_total', $total, $items); |
|
| 787 | 787 | |
| 788 | - return wpinv_sanitize_amount( $total ); |
|
| 788 | + return wpinv_sanitize_amount($total); |
|
| 789 | 789 | } |
| 790 | 790 | |
| 791 | -function wpinv_cart_total( $cart_items = array(), $echo = true, $invoice = array() ) { |
|
| 791 | +function wpinv_cart_total($cart_items = array(), $echo = true, $invoice = array()) { |
|
| 792 | 792 | global $cart_total; |
| 793 | - $total = wpinv_price( wpinv_format_amount( wpinv_get_cart_total( $cart_items, NULL, $invoice ) ), $invoice->get_currency() ); |
|
| 794 | - $total = apply_filters( 'wpinv_cart_total', $total, $cart_items, $invoice ); |
|
| 793 | + $total = wpinv_price(wpinv_format_amount(wpinv_get_cart_total($cart_items, NULL, $invoice)), $invoice->get_currency()); |
|
| 794 | + $total = apply_filters('wpinv_cart_total', $total, $cart_items, $invoice); |
|
| 795 | 795 | |
| 796 | 796 | $cart_total = $total; |
| 797 | 797 | |
| 798 | - if ( !$echo ) { |
|
| 798 | + if (!$echo) { |
|
| 799 | 799 | return $total; |
| 800 | 800 | } |
| 801 | 801 | |
| 802 | 802 | echo $total; |
| 803 | 803 | } |
| 804 | 804 | |
| 805 | -function wpinv_get_cart_tax( $items = array(), $invoice = 0 ) { |
|
| 805 | +function wpinv_get_cart_tax($items = array(), $invoice = 0) { |
|
| 806 | 806 | |
| 807 | - if ( ! empty( $invoice ) && ! $invoice->is_taxable() ) { |
|
| 807 | + if (!empty($invoice) && !$invoice->is_taxable()) { |
|
| 808 | 808 | return 0; |
| 809 | 809 | } |
| 810 | 810 | |
| 811 | 811 | $cart_tax = 0; |
| 812 | - $items = !empty( $items ) ? $items : wpinv_get_cart_content_details(); |
|
| 812 | + $items = !empty($items) ? $items : wpinv_get_cart_content_details(); |
|
| 813 | 813 | |
| 814 | - if ( $items ) { |
|
| 815 | - $taxes = wp_list_pluck( $items, 'tax' ); |
|
| 814 | + if ($items) { |
|
| 815 | + $taxes = wp_list_pluck($items, 'tax'); |
|
| 816 | 816 | |
| 817 | - if( is_array( $taxes ) ) { |
|
| 818 | - $cart_tax = array_sum( $taxes ); |
|
| 817 | + if (is_array($taxes)) { |
|
| 818 | + $cart_tax = array_sum($taxes); |
|
| 819 | 819 | } |
| 820 | 820 | } |
| 821 | 821 | |
| 822 | 822 | $cart_tax += wpinv_get_cart_fee_tax(); |
| 823 | 823 | |
| 824 | - return apply_filters( 'wpinv_get_cart_tax', wpinv_sanitize_amount( $cart_tax ) ); |
|
| 824 | + return apply_filters('wpinv_get_cart_tax', wpinv_sanitize_amount($cart_tax)); |
|
| 825 | 825 | } |
| 826 | 826 | |
| 827 | -function wpinv_cart_tax( $items = array(), $echo = false, $currency = '', $invoice = 0 ) { |
|
| 827 | +function wpinv_cart_tax($items = array(), $echo = false, $currency = '', $invoice = 0) { |
|
| 828 | 828 | |
| 829 | - if ( ! empty( $invoice && ! $invoice->is_taxable() ) ) { |
|
| 830 | - echo wpinv_price( wpinv_format_amount( 0 ), $currency ); |
|
| 829 | + if (!empty($invoice && !$invoice->is_taxable())) { |
|
| 830 | + echo wpinv_price(wpinv_format_amount(0), $currency); |
|
| 831 | 831 | return; |
| 832 | 832 | } |
| 833 | 833 | |
| 834 | - $cart_tax = wpinv_get_cart_tax( $items, $invoice ); |
|
| 835 | - $cart_tax = wpinv_price( wpinv_format_amount( $cart_tax ), $currency ); |
|
| 834 | + $cart_tax = wpinv_get_cart_tax($items, $invoice); |
|
| 835 | + $cart_tax = wpinv_price(wpinv_format_amount($cart_tax), $currency); |
|
| 836 | 836 | |
| 837 | - $tax = apply_filters( 'wpinv_cart_tax', $cart_tax, $items ); |
|
| 837 | + $tax = apply_filters('wpinv_cart_tax', $cart_tax, $items); |
|
| 838 | 838 | |
| 839 | - if ( !$echo ) { |
|
| 839 | + if (!$echo) { |
|
| 840 | 840 | return $tax; |
| 841 | 841 | } |
| 842 | 842 | |
| 843 | 843 | echo $tax; |
| 844 | 844 | } |
| 845 | 845 | |
| 846 | -function wpinv_get_cart_discount_code( $items = array() ) { |
|
| 846 | +function wpinv_get_cart_discount_code($items = array()) { |
|
| 847 | 847 | $invoice = wpinv_get_invoice_cart(); |
| 848 | - $cart_discount_code = !empty( $invoice ) ? $invoice->get_discount_code() : ''; |
|
| 848 | + $cart_discount_code = !empty($invoice) ? $invoice->get_discount_code() : ''; |
|
| 849 | 849 | |
| 850 | - return apply_filters( 'wpinv_get_cart_discount_code', $cart_discount_code ); |
|
| 850 | + return apply_filters('wpinv_get_cart_discount_code', $cart_discount_code); |
|
| 851 | 851 | } |
| 852 | 852 | |
| 853 | -function wpinv_cart_discount_code( $items = array(), $echo = false ) { |
|
| 854 | - $cart_discount_code = wpinv_get_cart_discount_code( $items ); |
|
| 853 | +function wpinv_cart_discount_code($items = array(), $echo = false) { |
|
| 854 | + $cart_discount_code = wpinv_get_cart_discount_code($items); |
|
| 855 | 855 | |
| 856 | - if ( $cart_discount_code != '' ) { |
|
| 856 | + if ($cart_discount_code != '') { |
|
| 857 | 857 | $cart_discount_code = ' (' . $cart_discount_code . ')'; |
| 858 | 858 | } |
| 859 | 859 | |
| 860 | - $discount_code = apply_filters( 'wpinv_cart_discount_code', $cart_discount_code, $items ); |
|
| 860 | + $discount_code = apply_filters('wpinv_cart_discount_code', $cart_discount_code, $items); |
|
| 861 | 861 | |
| 862 | - if ( !$echo ) { |
|
| 862 | + if (!$echo) { |
|
| 863 | 863 | return $discount_code; |
| 864 | 864 | } |
| 865 | 865 | |
| 866 | 866 | echo $discount_code; |
| 867 | 867 | } |
| 868 | 868 | |
| 869 | -function wpinv_get_cart_discount( $items = array() ) { |
|
| 869 | +function wpinv_get_cart_discount($items = array()) { |
|
| 870 | 870 | $invoice = wpinv_get_invoice_cart(); |
| 871 | - $cart_discount = !empty( $invoice ) ? $invoice->get_discount() : 0; |
|
| 871 | + $cart_discount = !empty($invoice) ? $invoice->get_discount() : 0; |
|
| 872 | 872 | |
| 873 | - return apply_filters( 'wpinv_get_cart_discount', wpinv_sanitize_amount( $cart_discount ), $items ); |
|
| 873 | + return apply_filters('wpinv_get_cart_discount', wpinv_sanitize_amount($cart_discount), $items); |
|
| 874 | 874 | } |
| 875 | 875 | |
| 876 | -function wpinv_cart_discount( $items = array(), $echo = false ) { |
|
| 877 | - $cart_discount = wpinv_get_cart_discount( $items ); |
|
| 878 | - $cart_discount = wpinv_price( wpinv_format_amount( $cart_discount ) ); |
|
| 876 | +function wpinv_cart_discount($items = array(), $echo = false) { |
|
| 877 | + $cart_discount = wpinv_get_cart_discount($items); |
|
| 878 | + $cart_discount = wpinv_price(wpinv_format_amount($cart_discount)); |
|
| 879 | 879 | |
| 880 | - $discount = apply_filters( 'wpinv_cart_discount', $cart_discount, $items ); |
|
| 880 | + $discount = apply_filters('wpinv_cart_discount', $cart_discount, $items); |
|
| 881 | 881 | |
| 882 | - if ( !$echo ) { |
|
| 882 | + if (!$echo) { |
|
| 883 | 883 | return $discount; |
| 884 | 884 | } |
| 885 | 885 | |
| 886 | 886 | echo $discount; |
| 887 | 887 | } |
| 888 | 888 | |
| 889 | -function wpinv_get_cart_fees( $type = 'all', $item_id = 0 ) { |
|
| 890 | - $item = new WPInv_Item( $item_id ); |
|
| 889 | +function wpinv_get_cart_fees($type = 'all', $item_id = 0) { |
|
| 890 | + $item = new WPInv_Item($item_id); |
|
| 891 | 891 | |
| 892 | - return $item->get_fees( $type, $item_id ); |
|
| 892 | + return $item->get_fees($type, $item_id); |
|
| 893 | 893 | } |
| 894 | 894 | |
| 895 | 895 | function wpinv_get_cart_fee_total() { |
| 896 | - $total = 0; |
|
| 896 | + $total = 0; |
|
| 897 | 897 | $fees = wpinv_get_cart_fees(); |
| 898 | 898 | |
| 899 | - if ( $fees ) { |
|
| 900 | - foreach ( $fees as $fee_id => $fee ) { |
|
| 899 | + if ($fees) { |
|
| 900 | + foreach ($fees as $fee_id => $fee) { |
|
| 901 | 901 | $total += $fee['amount']; |
| 902 | 902 | } |
| 903 | 903 | } |
| 904 | 904 | |
| 905 | - return apply_filters( 'wpinv_get_cart_fee_total', $total ); |
|
| 905 | + return apply_filters('wpinv_get_cart_fee_total', $total); |
|
| 906 | 906 | } |
| 907 | 907 | |
| 908 | 908 | function wpinv_get_cart_fee_tax() { |
| 909 | 909 | $tax = 0; |
| 910 | 910 | $fees = wpinv_get_cart_fees(); |
| 911 | 911 | |
| 912 | - if ( $fees ) { |
|
| 913 | - foreach ( $fees as $fee_id => $fee ) { |
|
| 914 | - if( ! empty( $fee['no_tax'] ) ) { |
|
| 912 | + if ($fees) { |
|
| 913 | + foreach ($fees as $fee_id => $fee) { |
|
| 914 | + if (!empty($fee['no_tax'])) { |
|
| 915 | 915 | continue; |
| 916 | 916 | } |
| 917 | 917 | |
| 918 | - $tax += wpinv_calculate_tax( $fee['amount'] ); |
|
| 918 | + $tax += wpinv_calculate_tax($fee['amount']); |
|
| 919 | 919 | } |
| 920 | 920 | } |
| 921 | 921 | |
| 922 | - return apply_filters( 'wpinv_get_cart_fee_tax', $tax ); |
|
| 922 | + return apply_filters('wpinv_get_cart_fee_tax', $tax); |
|
| 923 | 923 | } |
| 924 | 924 | |
| 925 | 925 | function wpinv_cart_has_recurring_item() { |
| 926 | 926 | $cart_items = wpinv_get_cart_contents(); |
| 927 | 927 | |
| 928 | - if ( empty( $cart_items ) ) { |
|
| 928 | + if (empty($cart_items)) { |
|
| 929 | 929 | return false; |
| 930 | 930 | } |
| 931 | 931 | |
| 932 | 932 | $has_subscription = false; |
| 933 | - foreach( $cart_items as $cart_item ) { |
|
| 934 | - if ( !empty( $cart_item['id'] ) && wpinv_is_recurring_item( $cart_item['id'] ) ) { |
|
| 933 | + foreach ($cart_items as $cart_item) { |
|
| 934 | + if (!empty($cart_item['id']) && wpinv_is_recurring_item($cart_item['id'])) { |
|
| 935 | 935 | $has_subscription = true; |
| 936 | 936 | break; |
| 937 | 937 | } |
| 938 | 938 | } |
| 939 | 939 | |
| 940 | - return apply_filters( 'wpinv_cart_has_recurring_item', $has_subscription, $cart_items ); |
|
| 940 | + return apply_filters('wpinv_cart_has_recurring_item', $has_subscription, $cart_items); |
|
| 941 | 941 | } |
| 942 | 942 | |
| 943 | 943 | function wpinv_cart_has_free_trial() { |
@@ -945,100 +945,100 @@ discard block |
||
| 945 | 945 | |
| 946 | 946 | $free_trial = false; |
| 947 | 947 | |
| 948 | - if ( !empty( $invoice ) && $invoice->is_free_trial() ) { |
|
| 948 | + if (!empty($invoice) && $invoice->is_free_trial()) { |
|
| 949 | 949 | $free_trial = true; |
| 950 | 950 | } |
| 951 | 951 | |
| 952 | - return apply_filters( 'wpinv_cart_has_free_trial', $free_trial, $invoice ); |
|
| 952 | + return apply_filters('wpinv_cart_has_free_trial', $free_trial, $invoice); |
|
| 953 | 953 | } |
| 954 | 954 | |
| 955 | 955 | function wpinv_get_cart_contents() { |
| 956 | 956 | $cart_details = wpinv_get_cart_details(); |
| 957 | 957 | |
| 958 | - return apply_filters( 'wpinv_get_cart_contents', $cart_details ); |
|
| 958 | + return apply_filters('wpinv_get_cart_contents', $cart_details); |
|
| 959 | 959 | } |
| 960 | 960 | |
| 961 | 961 | function wpinv_get_cart_content_details() { |
| 962 | 962 | global $wpinv_euvat, $wpi_current_id, $wpi_item_id, $wpinv_is_last_cart_item, $wpinv_flat_discount_total; |
| 963 | 963 | $cart_items = wpinv_get_cart_contents(); |
| 964 | 964 | |
| 965 | - if ( empty( $cart_items ) ) { |
|
| 965 | + if (empty($cart_items)) { |
|
| 966 | 966 | return false; |
| 967 | 967 | } |
| 968 | 968 | $invoice = wpinv_get_invoice_cart(); |
| 969 | - if ( empty( $invoice ) ) { |
|
| 969 | + if (empty($invoice)) { |
|
| 970 | 970 | return false; |
| 971 | 971 | } |
| 972 | 972 | |
| 973 | 973 | $details = array(); |
| 974 | - $length = count( $cart_items ) - 1; |
|
| 974 | + $length = count($cart_items) - 1; |
|
| 975 | 975 | |
| 976 | - if ( empty( $_POST['country'] ) ) { |
|
| 976 | + if (empty($_POST['country'])) { |
|
| 977 | 977 | $_POST['country'] = $invoice->country; |
| 978 | 978 | } |
| 979 | - if ( !isset( $_POST['state'] ) ) { |
|
| 979 | + if (!isset($_POST['state'])) { |
|
| 980 | 980 | $_POST['state'] = $invoice->state; |
| 981 | 981 | } |
| 982 | 982 | |
| 983 | - foreach( $cart_items as $key => $item ) { |
|
| 984 | - $item_id = isset( $item['id'] ) ? sanitize_text_field( $item['id'] ) : ''; |
|
| 985 | - if ( empty( $item_id ) ) { |
|
| 983 | + foreach ($cart_items as $key => $item) { |
|
| 984 | + $item_id = isset($item['id']) ? sanitize_text_field($item['id']) : ''; |
|
| 985 | + if (empty($item_id)) { |
|
| 986 | 986 | continue; |
| 987 | 987 | } |
| 988 | 988 | |
| 989 | 989 | $wpi_current_id = $invoice->ID; |
| 990 | 990 | $wpi_item_id = $item_id; |
| 991 | 991 | |
| 992 | - if ( isset( $item['custom_price'] ) && $item['custom_price'] !== '' ) { |
|
| 992 | + if (isset($item['custom_price']) && $item['custom_price'] !== '') { |
|
| 993 | 993 | $item_price = $item['custom_price']; |
| 994 | 994 | } else { |
| 995 | - if ( isset( $item['item_price'] ) && $item['item_price'] !== '' && $item['item_price'] !== false ) { |
|
| 995 | + if (isset($item['item_price']) && $item['item_price'] !== '' && $item['item_price'] !== false) { |
|
| 996 | 996 | $item_price = $item['item_price']; |
| 997 | 997 | } else { |
| 998 | - $item_price = wpinv_get_item_price( $item_id ); |
|
| 998 | + $item_price = wpinv_get_item_price($item_id); |
|
| 999 | 999 | } |
| 1000 | 1000 | } |
| 1001 | - $discount = wpinv_get_cart_item_discount_amount( $item ); |
|
| 1002 | - $discount = apply_filters( 'wpinv_get_cart_content_details_item_discount_amount', $discount, $item ); |
|
| 1003 | - $quantity = wpinv_get_cart_item_quantity( $item ); |
|
| 1004 | - $fees = wpinv_get_cart_fees( 'fee', $item_id ); |
|
| 1001 | + $discount = wpinv_get_cart_item_discount_amount($item); |
|
| 1002 | + $discount = apply_filters('wpinv_get_cart_content_details_item_discount_amount', $discount, $item); |
|
| 1003 | + $quantity = wpinv_get_cart_item_quantity($item); |
|
| 1004 | + $fees = wpinv_get_cart_fees('fee', $item_id); |
|
| 1005 | 1005 | |
| 1006 | 1006 | $subtotal = $item_price * $quantity; |
| 1007 | - $tax_rate = wpinv_get_tax_rate( $_POST['country'], $_POST['state'], $wpi_item_id ); |
|
| 1008 | - $tax_class = $wpinv_euvat->get_item_class( $item_id ); |
|
| 1009 | - $tax = wpinv_get_cart_item_tax( $item_id, $subtotal - $discount ); |
|
| 1007 | + $tax_rate = wpinv_get_tax_rate($_POST['country'], $_POST['state'], $wpi_item_id); |
|
| 1008 | + $tax_class = $wpinv_euvat->get_item_class($item_id); |
|
| 1009 | + $tax = wpinv_get_cart_item_tax($item_id, $subtotal - $discount); |
|
| 1010 | 1010 | |
| 1011 | - if ( ! $invoice->is_taxable() ) { |
|
| 1011 | + if (!$invoice->is_taxable()) { |
|
| 1012 | 1012 | $tax = 0; |
| 1013 | 1013 | } |
| 1014 | - if ( wpinv_prices_include_tax() ) { |
|
| 1015 | - $subtotal -= wpinv_round_amount( $tax ); |
|
| 1014 | + if (wpinv_prices_include_tax()) { |
|
| 1015 | + $subtotal -= wpinv_round_amount($tax); |
|
| 1016 | 1016 | } |
| 1017 | 1017 | |
| 1018 | - $total = $subtotal - $discount + $tax; |
|
| 1018 | + $total = $subtotal - $discount + $tax; |
|
| 1019 | 1019 | |
| 1020 | 1020 | // Do not allow totals to go negatve |
| 1021 | - if( $total < 0 ) { |
|
| 1021 | + if ($total < 0) { |
|
| 1022 | 1022 | $total = 0; |
| 1023 | 1023 | } |
| 1024 | 1024 | |
| 1025 | - $details[ $key ] = array( |
|
| 1025 | + $details[$key] = array( |
|
| 1026 | 1026 | 'id' => $item_id, |
| 1027 | - 'name' => !empty($item['name']) ? $item['name'] : get_the_title( $item_id ), |
|
| 1028 | - 'item_price' => wpinv_round_amount( $item_price ), |
|
| 1029 | - 'custom_price' => isset( $item['custom_price'] ) ? $item['custom_price'] : '', |
|
| 1027 | + 'name' => !empty($item['name']) ? $item['name'] : get_the_title($item_id), |
|
| 1028 | + 'item_price' => wpinv_round_amount($item_price), |
|
| 1029 | + 'custom_price' => isset($item['custom_price']) ? $item['custom_price'] : '', |
|
| 1030 | 1030 | 'quantity' => $quantity, |
| 1031 | - 'discount' => wpinv_round_amount( $discount ), |
|
| 1032 | - 'subtotal' => wpinv_round_amount( $subtotal ), |
|
| 1033 | - 'tax' => wpinv_round_amount( $tax ), |
|
| 1034 | - 'price' => wpinv_round_amount( $total ), |
|
| 1031 | + 'discount' => wpinv_round_amount($discount), |
|
| 1032 | + 'subtotal' => wpinv_round_amount($subtotal), |
|
| 1033 | + 'tax' => wpinv_round_amount($tax), |
|
| 1034 | + 'price' => wpinv_round_amount($total), |
|
| 1035 | 1035 | 'vat_rates_class' => $tax_class, |
| 1036 | 1036 | 'vat_rate' => $tax_rate, |
| 1037 | - 'meta' => isset( $item['meta'] ) ? $item['meta'] : array(), |
|
| 1037 | + 'meta' => isset($item['meta']) ? $item['meta'] : array(), |
|
| 1038 | 1038 | 'fees' => $fees, |
| 1039 | 1039 | ); |
| 1040 | 1040 | |
| 1041 | - if ( $wpinv_is_last_cart_item ) { |
|
| 1041 | + if ($wpinv_is_last_cart_item) { |
|
| 1042 | 1042 | $wpinv_is_last_cart_item = false; |
| 1043 | 1043 | $wpinv_flat_discount_total = 0.00; |
| 1044 | 1044 | } |
@@ -1047,67 +1047,67 @@ discard block |
||
| 1047 | 1047 | return $details; |
| 1048 | 1048 | } |
| 1049 | 1049 | |
| 1050 | -function wpinv_get_cart_details( $invoice_id = 0 ) { |
|
| 1050 | +function wpinv_get_cart_details($invoice_id = 0) { |
|
| 1051 | 1051 | global $ajax_cart_details; |
| 1052 | 1052 | |
| 1053 | - $invoice = wpinv_get_invoice_cart( $invoice_id ); |
|
| 1053 | + $invoice = wpinv_get_invoice_cart($invoice_id); |
|
| 1054 | 1054 | $cart_details = $ajax_cart_details; |
| 1055 | - if ( empty( $cart_details ) && ! empty( $invoice->cart_details ) ) { |
|
| 1055 | + if (empty($cart_details) && !empty($invoice->cart_details)) { |
|
| 1056 | 1056 | $cart_details = $invoice->cart_details; |
| 1057 | 1057 | } |
| 1058 | 1058 | |
| 1059 | - if ( ! empty( $cart_details ) && is_array( $cart_details ) ) { |
|
| 1060 | - $invoice_currency = ! empty( $invoice->currency ) ? $invoice->currency : wpinv_get_default_country(); |
|
| 1059 | + if (!empty($cart_details) && is_array($cart_details)) { |
|
| 1060 | + $invoice_currency = !empty($invoice->currency) ? $invoice->currency : wpinv_get_default_country(); |
|
| 1061 | 1061 | |
| 1062 | - foreach ( $cart_details as $key => $cart_item ) { |
|
| 1063 | - $cart_details[ $key ]['currency'] = $invoice_currency; |
|
| 1062 | + foreach ($cart_details as $key => $cart_item) { |
|
| 1063 | + $cart_details[$key]['currency'] = $invoice_currency; |
|
| 1064 | 1064 | |
| 1065 | - if ( ! isset( $cart_item['subtotal'] ) ) { |
|
| 1066 | - $cart_details[ $key ]['subtotal'] = $cart_item['price']; |
|
| 1065 | + if (!isset($cart_item['subtotal'])) { |
|
| 1066 | + $cart_details[$key]['subtotal'] = $cart_item['price']; |
|
| 1067 | 1067 | } |
| 1068 | 1068 | } |
| 1069 | 1069 | } |
| 1070 | 1070 | |
| 1071 | - return apply_filters( 'wpinv_get_cart_details', $cart_details, $invoice_id ); |
|
| 1071 | + return apply_filters('wpinv_get_cart_details', $cart_details, $invoice_id); |
|
| 1072 | 1072 | } |
| 1073 | 1073 | |
| 1074 | -function wpinv_record_status_change( $invoice_id, $new_status, $old_status ) { |
|
| 1075 | - if ( 'wpi_invoice' != get_post_type( $invoice_id ) ) { |
|
| 1074 | +function wpinv_record_status_change($invoice_id, $new_status, $old_status) { |
|
| 1075 | + if ('wpi_invoice' != get_post_type($invoice_id)) { |
|
| 1076 | 1076 | return; |
| 1077 | 1077 | } |
| 1078 | 1078 | |
| 1079 | - if ( ( $old_status == 'wpi-pending' && $new_status == 'draft' ) || ( $old_status == 'draft' && $new_status == 'wpi-pending' ) ) { |
|
| 1079 | + if (($old_status == 'wpi-pending' && $new_status == 'draft') || ($old_status == 'draft' && $new_status == 'wpi-pending')) { |
|
| 1080 | 1080 | return; |
| 1081 | 1081 | } |
| 1082 | 1082 | |
| 1083 | - $invoice = wpinv_get_invoice( $invoice_id ); |
|
| 1083 | + $invoice = wpinv_get_invoice($invoice_id); |
|
| 1084 | 1084 | |
| 1085 | - $old_status = wpinv_status_nicename( $old_status ); |
|
| 1086 | - $new_status = wpinv_status_nicename( $new_status ); |
|
| 1085 | + $old_status = wpinv_status_nicename($old_status); |
|
| 1086 | + $new_status = wpinv_status_nicename($new_status); |
|
| 1087 | 1087 | |
| 1088 | - $status_change = sprintf( __( 'Invoice status changed from %s to %s', 'invoicing' ), $old_status, $new_status ); |
|
| 1088 | + $status_change = sprintf(__('Invoice status changed from %s to %s', 'invoicing'), $old_status, $new_status); |
|
| 1089 | 1089 | |
| 1090 | 1090 | // Add note |
| 1091 | - return $invoice->add_note( $status_change, false, false, true ); |
|
| 1091 | + return $invoice->add_note($status_change, false, false, true); |
|
| 1092 | 1092 | } |
| 1093 | -add_action( 'wpinv_update_status', 'wpinv_record_status_change', 100, 3 ); |
|
| 1093 | +add_action('wpinv_update_status', 'wpinv_record_status_change', 100, 3); |
|
| 1094 | 1094 | |
| 1095 | -function wpinv_complete_payment( $invoice_id, $new_status, $old_status ) { |
|
| 1095 | +function wpinv_complete_payment($invoice_id, $new_status, $old_status) { |
|
| 1096 | 1096 | global $wpi_has_free_trial; |
| 1097 | 1097 | |
| 1098 | 1098 | $wpi_has_free_trial = false; |
| 1099 | 1099 | |
| 1100 | - if ( $old_status == 'publish' ) { |
|
| 1100 | + if ($old_status == 'publish') { |
|
| 1101 | 1101 | return; // Make sure that payments are only paid once |
| 1102 | 1102 | } |
| 1103 | 1103 | |
| 1104 | 1104 | // Make sure the payment completion is only processed when new status is paid |
| 1105 | - if ( $new_status != 'publish' ) { |
|
| 1105 | + if ($new_status != 'publish') { |
|
| 1106 | 1106 | return; |
| 1107 | 1107 | } |
| 1108 | 1108 | |
| 1109 | - $invoice = new WPInv_Invoice( $invoice_id ); |
|
| 1110 | - if ( empty( $invoice ) ) { |
|
| 1109 | + $invoice = new WPInv_Invoice($invoice_id); |
|
| 1110 | + if (empty($invoice)) { |
|
| 1111 | 1111 | return; |
| 1112 | 1112 | } |
| 1113 | 1113 | |
@@ -1115,58 +1115,58 @@ discard block |
||
| 1115 | 1115 | $completed_date = $invoice->completed_date; |
| 1116 | 1116 | $cart_details = $invoice->cart_details; |
| 1117 | 1117 | |
| 1118 | - do_action( 'wpinv_pre_complete_payment', $invoice_id ); |
|
| 1118 | + do_action('wpinv_pre_complete_payment', $invoice_id); |
|
| 1119 | 1119 | |
| 1120 | - if ( is_array( $cart_details ) ) { |
|
| 1120 | + if (is_array($cart_details)) { |
|
| 1121 | 1121 | // Increase purchase count and earnings |
| 1122 | - foreach ( $cart_details as $cart_index => $item ) { |
|
| 1122 | + foreach ($cart_details as $cart_index => $item) { |
|
| 1123 | 1123 | // Ensure these actions only run once, ever |
| 1124 | - if ( empty( $completed_date ) ) { |
|
| 1125 | - do_action( 'wpinv_complete_item_payment', $item['id'], $invoice_id, $item, $cart_index ); |
|
| 1124 | + if (empty($completed_date)) { |
|
| 1125 | + do_action('wpinv_complete_item_payment', $item['id'], $invoice_id, $item, $cart_index); |
|
| 1126 | 1126 | } |
| 1127 | 1127 | } |
| 1128 | 1128 | } |
| 1129 | 1129 | |
| 1130 | 1130 | // Check for discount codes and increment their use counts |
| 1131 | - if ( $discounts = $invoice->get_discounts( true ) ) { |
|
| 1132 | - if( ! empty( $discounts ) ) { |
|
| 1133 | - foreach( $discounts as $code ) { |
|
| 1134 | - wpinv_increase_discount_usage( $code ); |
|
| 1131 | + if ($discounts = $invoice->get_discounts(true)) { |
|
| 1132 | + if (!empty($discounts)) { |
|
| 1133 | + foreach ($discounts as $code) { |
|
| 1134 | + wpinv_increase_discount_usage($code); |
|
| 1135 | 1135 | } |
| 1136 | 1136 | } |
| 1137 | 1137 | } |
| 1138 | 1138 | |
| 1139 | 1139 | // Ensure this action only runs once ever |
| 1140 | - if( empty( $completed_date ) ) { |
|
| 1140 | + if (empty($completed_date)) { |
|
| 1141 | 1141 | // Save the completed date |
| 1142 | - $invoice->set( 'completed_date', current_time( 'mysql', 0 ) ); |
|
| 1142 | + $invoice->set('completed_date', current_time('mysql', 0)); |
|
| 1143 | 1143 | $invoice->save(); |
| 1144 | 1144 | |
| 1145 | - do_action( 'wpinv_complete_payment', $invoice_id ); |
|
| 1145 | + do_action('wpinv_complete_payment', $invoice_id); |
|
| 1146 | 1146 | } |
| 1147 | 1147 | |
| 1148 | 1148 | // Empty the shopping cart |
| 1149 | 1149 | wpinv_empty_cart(); |
| 1150 | 1150 | } |
| 1151 | -add_action( 'wpinv_update_status', 'wpinv_complete_payment', 100, 3 ); |
|
| 1151 | +add_action('wpinv_update_status', 'wpinv_complete_payment', 100, 3); |
|
| 1152 | 1152 | |
| 1153 | -function wpinv_update_payment_status( $invoice_id, $new_status = 'publish' ) { |
|
| 1154 | - $invoice = !empty( $invoice_id ) && is_object( $invoice_id ) ? $invoice_id : wpinv_get_invoice( (int)$invoice_id ); |
|
| 1153 | +function wpinv_update_payment_status($invoice_id, $new_status = 'publish') { |
|
| 1154 | + $invoice = !empty($invoice_id) && is_object($invoice_id) ? $invoice_id : wpinv_get_invoice((int) $invoice_id); |
|
| 1155 | 1155 | |
| 1156 | - if ( empty( $invoice ) ) { |
|
| 1156 | + if (empty($invoice)) { |
|
| 1157 | 1157 | return false; |
| 1158 | 1158 | } |
| 1159 | 1159 | |
| 1160 | - return $invoice->update_status( $new_status ); |
|
| 1160 | + return $invoice->update_status($new_status); |
|
| 1161 | 1161 | } |
| 1162 | 1162 | |
| 1163 | -function wpinv_cart_has_fees( $type = 'all' ) { |
|
| 1163 | +function wpinv_cart_has_fees($type = 'all') { |
|
| 1164 | 1164 | return false; |
| 1165 | 1165 | } |
| 1166 | 1166 | |
| 1167 | 1167 | function wpinv_validate_checkout_fields() { |
| 1168 | 1168 | // Check if there is $_POST |
| 1169 | - if ( empty( $_POST ) ) { |
|
| 1169 | + if (empty($_POST)) { |
|
| 1170 | 1170 | return false; |
| 1171 | 1171 | } |
| 1172 | 1172 | |
@@ -1189,28 +1189,28 @@ discard block |
||
| 1189 | 1189 | |
| 1190 | 1190 | $invoice = wpinv_get_invoice_cart(); |
| 1191 | 1191 | $has_subscription = $invoice->is_recurring(); |
| 1192 | - if ( empty( $invoice ) ) { |
|
| 1193 | - wpinv_set_error( 'invalid_invoice', __( 'Your cart is empty.', 'invoicing' ) ); |
|
| 1192 | + if (empty($invoice)) { |
|
| 1193 | + wpinv_set_error('invalid_invoice', __('Your cart is empty.', 'invoicing')); |
|
| 1194 | 1194 | return $gateway; |
| 1195 | 1195 | } |
| 1196 | 1196 | |
| 1197 | 1197 | // Check if a gateway value is present |
| 1198 | - if ( !empty( $_REQUEST['wpi-gateway'] ) ) { |
|
| 1199 | - $gateway = sanitize_text_field( $_REQUEST['wpi-gateway'] ); |
|
| 1198 | + if (!empty($_REQUEST['wpi-gateway'])) { |
|
| 1199 | + $gateway = sanitize_text_field($_REQUEST['wpi-gateway']); |
|
| 1200 | 1200 | |
| 1201 | - if ( $invoice->is_free() ) { |
|
| 1201 | + if ($invoice->is_free()) { |
|
| 1202 | 1202 | $gateway = 'manual'; |
| 1203 | - } elseif ( !wpinv_is_gateway_active( $gateway ) ) { |
|
| 1204 | - wpinv_set_error( 'invalid_gateway', __( 'The selected payment gateway is not enabled', 'invoicing' ) ); |
|
| 1205 | - } elseif ( $has_subscription && !wpinv_gateway_support_subscription( $gateway ) ) { |
|
| 1206 | - if ( apply_filters( 'wpinv_reject_non_recurring_gateway', true ) ) { |
|
| 1207 | - wpinv_set_error( 'invalid_gateway', __( 'The selected payment gateway does not support subscription payment', 'invoicing' ) ); |
|
| 1203 | + } elseif (!wpinv_is_gateway_active($gateway)) { |
|
| 1204 | + wpinv_set_error('invalid_gateway', __('The selected payment gateway is not enabled', 'invoicing')); |
|
| 1205 | + } elseif ($has_subscription && !wpinv_gateway_support_subscription($gateway)) { |
|
| 1206 | + if (apply_filters('wpinv_reject_non_recurring_gateway', true)) { |
|
| 1207 | + wpinv_set_error('invalid_gateway', __('The selected payment gateway does not support subscription payment', 'invoicing')); |
|
| 1208 | 1208 | } |
| 1209 | 1209 | } |
| 1210 | 1210 | } |
| 1211 | 1211 | |
| 1212 | - if ( $has_subscription && count( wpinv_get_cart_contents() ) > 1 ) { |
|
| 1213 | - wpinv_set_error( 'subscription_invalid', __( 'Only one subscription may be purchased through payment per checkout.', 'invoicing' ) ); |
|
| 1212 | + if ($has_subscription && count(wpinv_get_cart_contents()) > 1) { |
|
| 1213 | + wpinv_set_error('subscription_invalid', __('Only one subscription may be purchased through payment per checkout.', 'invoicing')); |
|
| 1214 | 1214 | } |
| 1215 | 1215 | |
| 1216 | 1216 | return $gateway; |
@@ -1224,10 +1224,10 @@ discard block |
||
| 1224 | 1224 | |
| 1225 | 1225 | $error = false; |
| 1226 | 1226 | // If we have discounts, loop through them |
| 1227 | - if ( ! empty( $discounts ) ) { |
|
| 1228 | - foreach ( $discounts as $discount ) { |
|
| 1227 | + if (!empty($discounts)) { |
|
| 1228 | + foreach ($discounts as $discount) { |
|
| 1229 | 1229 | // Check if valid |
| 1230 | - if ( !wpinv_is_discount_valid( $discount, (int)$wpi_cart->get_user_id() ) ) { |
|
| 1230 | + if (!wpinv_is_discount_valid($discount, (int) $wpi_cart->get_user_id())) { |
|
| 1231 | 1231 | // Discount is not valid |
| 1232 | 1232 | $error = true; |
| 1233 | 1233 | } |
@@ -1237,20 +1237,20 @@ discard block |
||
| 1237 | 1237 | return NULL; |
| 1238 | 1238 | } |
| 1239 | 1239 | |
| 1240 | - if ( $error && !wpinv_get_errors() ) { |
|
| 1241 | - wpinv_set_error( 'invalid_discount', __( 'Discount code you entered is invalid', 'invoicing' ) ); |
|
| 1240 | + if ($error && !wpinv_get_errors()) { |
|
| 1241 | + wpinv_set_error('invalid_discount', __('Discount code you entered is invalid', 'invoicing')); |
|
| 1242 | 1242 | } |
| 1243 | 1243 | |
| 1244 | - return implode( ',', $discounts ); |
|
| 1244 | + return implode(',', $discounts); |
|
| 1245 | 1245 | } |
| 1246 | 1246 | |
| 1247 | 1247 | function wpinv_checkout_validate_cc() { |
| 1248 | 1248 | $card_data = wpinv_checkout_get_cc_info(); |
| 1249 | 1249 | |
| 1250 | 1250 | // Validate the card zip |
| 1251 | - if ( !empty( $card_data['wpinv_zip'] ) ) { |
|
| 1252 | - if ( !wpinv_checkout_validate_cc_zip( $card_data['wpinv_zip'], $card_data['wpinv_country'] ) ) { |
|
| 1253 | - wpinv_set_error( 'invalid_cc_zip', __( 'The zip / postcode you entered for your billing address is invalid', 'invoicing' ) ); |
|
| 1251 | + if (!empty($card_data['wpinv_zip'])) { |
|
| 1252 | + if (!wpinv_checkout_validate_cc_zip($card_data['wpinv_zip'], $card_data['wpinv_country'])) { |
|
| 1253 | + wpinv_set_error('invalid_cc_zip', __('The zip / postcode you entered for your billing address is invalid', 'invoicing')); |
|
| 1254 | 1254 | } |
| 1255 | 1255 | } |
| 1256 | 1256 | |
@@ -1260,28 +1260,28 @@ discard block |
||
| 1260 | 1260 | |
| 1261 | 1261 | function wpinv_checkout_get_cc_info() { |
| 1262 | 1262 | $cc_info = array(); |
| 1263 | - $cc_info['card_name'] = isset( $_POST['card_name'] ) ? sanitize_text_field( $_POST['card_name'] ) : ''; |
|
| 1264 | - $cc_info['card_number'] = isset( $_POST['card_number'] ) ? sanitize_text_field( $_POST['card_number'] ) : ''; |
|
| 1265 | - $cc_info['card_cvc'] = isset( $_POST['card_cvc'] ) ? sanitize_text_field( $_POST['card_cvc'] ) : ''; |
|
| 1266 | - $cc_info['card_exp_month'] = isset( $_POST['card_exp_month'] ) ? sanitize_text_field( $_POST['card_exp_month'] ) : ''; |
|
| 1267 | - $cc_info['card_exp_year'] = isset( $_POST['card_exp_year'] ) ? sanitize_text_field( $_POST['card_exp_year'] ) : ''; |
|
| 1268 | - $cc_info['card_address'] = isset( $_POST['wpinv_address'] ) ? sanitize_text_field( $_POST['wpinv_address'] ) : ''; |
|
| 1269 | - $cc_info['card_city'] = isset( $_POST['wpinv_city'] ) ? sanitize_text_field( $_POST['wpinv_city'] ) : ''; |
|
| 1270 | - $cc_info['card_state'] = isset( $_POST['wpinv_state'] ) ? sanitize_text_field( $_POST['wpinv_state'] ) : ''; |
|
| 1271 | - $cc_info['card_country'] = isset( $_POST['wpinv_country'] ) ? sanitize_text_field( $_POST['wpinv_country'] ) : ''; |
|
| 1272 | - $cc_info['card_zip'] = isset( $_POST['wpinv_zip'] ) ? sanitize_text_field( $_POST['wpinv_zip'] ) : ''; |
|
| 1263 | + $cc_info['card_name'] = isset($_POST['card_name']) ? sanitize_text_field($_POST['card_name']) : ''; |
|
| 1264 | + $cc_info['card_number'] = isset($_POST['card_number']) ? sanitize_text_field($_POST['card_number']) : ''; |
|
| 1265 | + $cc_info['card_cvc'] = isset($_POST['card_cvc']) ? sanitize_text_field($_POST['card_cvc']) : ''; |
|
| 1266 | + $cc_info['card_exp_month'] = isset($_POST['card_exp_month']) ? sanitize_text_field($_POST['card_exp_month']) : ''; |
|
| 1267 | + $cc_info['card_exp_year'] = isset($_POST['card_exp_year']) ? sanitize_text_field($_POST['card_exp_year']) : ''; |
|
| 1268 | + $cc_info['card_address'] = isset($_POST['wpinv_address']) ? sanitize_text_field($_POST['wpinv_address']) : ''; |
|
| 1269 | + $cc_info['card_city'] = isset($_POST['wpinv_city']) ? sanitize_text_field($_POST['wpinv_city']) : ''; |
|
| 1270 | + $cc_info['card_state'] = isset($_POST['wpinv_state']) ? sanitize_text_field($_POST['wpinv_state']) : ''; |
|
| 1271 | + $cc_info['card_country'] = isset($_POST['wpinv_country']) ? sanitize_text_field($_POST['wpinv_country']) : ''; |
|
| 1272 | + $cc_info['card_zip'] = isset($_POST['wpinv_zip']) ? sanitize_text_field($_POST['wpinv_zip']) : ''; |
|
| 1273 | 1273 | |
| 1274 | 1274 | // Return cc info |
| 1275 | 1275 | return $cc_info; |
| 1276 | 1276 | } |
| 1277 | 1277 | |
| 1278 | -function wpinv_checkout_validate_cc_zip( $zip = 0, $country_code = '' ) { |
|
| 1278 | +function wpinv_checkout_validate_cc_zip($zip = 0, $country_code = '') { |
|
| 1279 | 1279 | $ret = false; |
| 1280 | 1280 | |
| 1281 | - if ( empty( $zip ) || empty( $country_code ) ) |
|
| 1281 | + if (empty($zip) || empty($country_code)) |
|
| 1282 | 1282 | return $ret; |
| 1283 | 1283 | |
| 1284 | - $country_code = strtoupper( $country_code ); |
|
| 1284 | + $country_code = strtoupper($country_code); |
|
| 1285 | 1285 | |
| 1286 | 1286 | $zip_regex = array( |
| 1287 | 1287 | "AD" => "AD\d{3}", |
@@ -1441,72 +1441,72 @@ discard block |
||
| 1441 | 1441 | "ZM" => "\d{5}" |
| 1442 | 1442 | ); |
| 1443 | 1443 | |
| 1444 | - if ( ! isset ( $zip_regex[ $country_code ] ) || preg_match( "/" . $zip_regex[ $country_code ] . "/i", $zip ) ) |
|
| 1444 | + if (!isset ($zip_regex[$country_code]) || preg_match("/" . $zip_regex[$country_code] . "/i", $zip)) |
|
| 1445 | 1445 | $ret = true; |
| 1446 | 1446 | |
| 1447 | - return apply_filters( 'wpinv_is_zip_valid', $ret, $zip, $country_code ); |
|
| 1447 | + return apply_filters('wpinv_is_zip_valid', $ret, $zip, $country_code); |
|
| 1448 | 1448 | } |
| 1449 | 1449 | |
| 1450 | 1450 | function wpinv_checkout_validate_agree_to_terms() { |
| 1451 | 1451 | // Validate agree to terms |
| 1452 | - if ( ! isset( $_POST['wpi_agree_to_terms'] ) || $_POST['wpi_agree_to_terms'] != 1 ) { |
|
| 1452 | + if (!isset($_POST['wpi_agree_to_terms']) || $_POST['wpi_agree_to_terms'] != 1) { |
|
| 1453 | 1453 | // User did not agree |
| 1454 | - wpinv_set_error( 'agree_to_terms', apply_filters( 'wpinv_agree_to_terms_text', __( 'You must agree to the terms of use', 'invoicing' ) ) ); |
|
| 1454 | + wpinv_set_error('agree_to_terms', apply_filters('wpinv_agree_to_terms_text', __('You must agree to the terms of use', 'invoicing'))); |
|
| 1455 | 1455 | } |
| 1456 | 1456 | } |
| 1457 | 1457 | |
| 1458 | 1458 | function wpinv_checkout_validate_invoice_user() { |
| 1459 | 1459 | global $wpi_cart, $user_ID; |
| 1460 | 1460 | |
| 1461 | - if(empty($wpi_cart)){ |
|
| 1461 | + if (empty($wpi_cart)) { |
|
| 1462 | 1462 | $wpi_cart = wpinv_get_invoice_cart(); |
| 1463 | 1463 | } |
| 1464 | 1464 | |
| 1465 | - $invoice_user = (int)$wpi_cart->get_user_id(); |
|
| 1465 | + $invoice_user = (int) $wpi_cart->get_user_id(); |
|
| 1466 | 1466 | $valid_user_data = array( |
| 1467 | 1467 | 'user_id' => $invoice_user |
| 1468 | 1468 | ); |
| 1469 | 1469 | |
| 1470 | 1470 | // If guest checkout allowed |
| 1471 | - if ( !wpinv_require_login_to_checkout() ) { |
|
| 1471 | + if (!wpinv_require_login_to_checkout()) { |
|
| 1472 | 1472 | return $valid_user_data; |
| 1473 | 1473 | } |
| 1474 | 1474 | |
| 1475 | 1475 | // Verify there is a user_ID |
| 1476 | - if ( $user_ID == $invoice_user ) { |
|
| 1476 | + if ($user_ID == $invoice_user) { |
|
| 1477 | 1477 | // Get the logged in user data |
| 1478 | - $user_data = get_userdata( $user_ID ); |
|
| 1479 | - $required_fields = wpinv_checkout_required_fields(); |
|
| 1478 | + $user_data = get_userdata($user_ID); |
|
| 1479 | + $required_fields = wpinv_checkout_required_fields(); |
|
| 1480 | 1480 | |
| 1481 | 1481 | // Loop through required fields and show error messages |
| 1482 | - if ( !empty( $required_fields ) ) { |
|
| 1483 | - foreach ( $required_fields as $field_name => $value ) { |
|
| 1484 | - if ( in_array( $value, $required_fields ) && empty( $_POST[ 'wpinv_' . $field_name ] ) ) { |
|
| 1485 | - wpinv_set_error( $value['error_id'], $value['error_message'] ); |
|
| 1482 | + if (!empty($required_fields)) { |
|
| 1483 | + foreach ($required_fields as $field_name => $value) { |
|
| 1484 | + if (in_array($value, $required_fields) && empty($_POST['wpinv_' . $field_name])) { |
|
| 1485 | + wpinv_set_error($value['error_id'], $value['error_message']); |
|
| 1486 | 1486 | } |
| 1487 | 1487 | } |
| 1488 | 1488 | } |
| 1489 | 1489 | |
| 1490 | 1490 | // Verify data |
| 1491 | - if ( $user_data ) { |
|
| 1491 | + if ($user_data) { |
|
| 1492 | 1492 | // Collected logged in user data |
| 1493 | 1493 | $valid_user_data = array( |
| 1494 | 1494 | 'user_id' => $user_ID, |
| 1495 | - 'email' => isset( $_POST['wpinv_email'] ) ? sanitize_email( $_POST['wpinv_email'] ) : $user_data->user_email, |
|
| 1496 | - 'first_name' => isset( $_POST['wpinv_first_name'] ) && ! empty( $_POST['wpinv_first_name'] ) ? sanitize_text_field( $_POST['wpinv_first_name'] ) : $user_data->first_name, |
|
| 1497 | - 'last_name' => isset( $_POST['wpinv_last_name'] ) && ! empty( $_POST['wpinv_last_name'] ) ? sanitize_text_field( $_POST['wpinv_last_name'] ) : $user_data->last_name, |
|
| 1495 | + 'email' => isset($_POST['wpinv_email']) ? sanitize_email($_POST['wpinv_email']) : $user_data->user_email, |
|
| 1496 | + 'first_name' => isset($_POST['wpinv_first_name']) && !empty($_POST['wpinv_first_name']) ? sanitize_text_field($_POST['wpinv_first_name']) : $user_data->first_name, |
|
| 1497 | + 'last_name' => isset($_POST['wpinv_last_name']) && !empty($_POST['wpinv_last_name']) ? sanitize_text_field($_POST['wpinv_last_name']) : $user_data->last_name, |
|
| 1498 | 1498 | ); |
| 1499 | 1499 | |
| 1500 | - if ( !empty( $_POST[ 'wpinv_email' ] ) && !is_email( $_POST[ 'wpinv_email' ] ) ) { |
|
| 1501 | - wpinv_set_error( 'invalid_email', __( 'Please enter a valid email address', 'invoicing' ) ); |
|
| 1500 | + if (!empty($_POST['wpinv_email']) && !is_email($_POST['wpinv_email'])) { |
|
| 1501 | + wpinv_set_error('invalid_email', __('Please enter a valid email address', 'invoicing')); |
|
| 1502 | 1502 | } |
| 1503 | 1503 | } else { |
| 1504 | 1504 | // Set invalid user error |
| 1505 | - wpinv_set_error( 'invalid_user', __( 'The user billing information is invalid', 'invoicing' ) ); |
|
| 1505 | + wpinv_set_error('invalid_user', __('The user billing information is invalid', 'invoicing')); |
|
| 1506 | 1506 | } |
| 1507 | 1507 | } else { |
| 1508 | 1508 | // Set invalid user error |
| 1509 | - wpinv_set_error( 'invalid_user_id', __( 'The invalid invoice user id', 'invoicing' ) ); |
|
| 1509 | + wpinv_set_error('invalid_user_id', __('The invalid invoice user id', 'invoicing')); |
|
| 1510 | 1510 | } |
| 1511 | 1511 | |
| 1512 | 1512 | // Return user data |
@@ -1518,27 +1518,27 @@ discard block |
||
| 1518 | 1518 | |
| 1519 | 1519 | $data = array(); |
| 1520 | 1520 | |
| 1521 | - if ( is_user_logged_in() ) { |
|
| 1522 | - if ( !wpinv_require_login_to_checkout() || ( wpinv_require_login_to_checkout() && (int)$wpi_cart->get_user_id() === (int)get_current_user_id() ) ) { |
|
| 1523 | - $data['user_id'] = (int)get_current_user_id(); |
|
| 1521 | + if (is_user_logged_in()) { |
|
| 1522 | + if (!wpinv_require_login_to_checkout() || (wpinv_require_login_to_checkout() && (int) $wpi_cart->get_user_id() === (int) get_current_user_id())) { |
|
| 1523 | + $data['user_id'] = (int) get_current_user_id(); |
|
| 1524 | 1524 | } else { |
| 1525 | - wpinv_set_error( 'logged_in_only', __( 'You are not allowed to pay for this invoice', 'invoicing' ) ); |
|
| 1525 | + wpinv_set_error('logged_in_only', __('You are not allowed to pay for this invoice', 'invoicing')); |
|
| 1526 | 1526 | } |
| 1527 | 1527 | } else { |
| 1528 | 1528 | // If guest checkout allowed |
| 1529 | - if ( !wpinv_require_login_to_checkout() ) { |
|
| 1529 | + if (!wpinv_require_login_to_checkout()) { |
|
| 1530 | 1530 | $data['user_id'] = 0; |
| 1531 | 1531 | } else { |
| 1532 | - wpinv_set_error( 'logged_in_only', __( 'You must be logged in to pay for this invoice', 'invoicing' ) ); |
|
| 1532 | + wpinv_set_error('logged_in_only', __('You must be logged in to pay for this invoice', 'invoicing')); |
|
| 1533 | 1533 | } |
| 1534 | 1534 | } |
| 1535 | 1535 | |
| 1536 | 1536 | return $data; |
| 1537 | 1537 | } |
| 1538 | 1538 | |
| 1539 | -function wpinv_checkout_form_get_user( $valid_data = array() ) { |
|
| 1539 | +function wpinv_checkout_form_get_user($valid_data = array()) { |
|
| 1540 | 1540 | |
| 1541 | - if ( !empty( $valid_data['current_user']['user_id'] ) ) { |
|
| 1541 | + if (!empty($valid_data['current_user']['user_id'])) { |
|
| 1542 | 1542 | $user = $valid_data['current_user']; |
| 1543 | 1543 | } else { |
| 1544 | 1544 | // Set the valid invoice user |
@@ -1546,7 +1546,7 @@ discard block |
||
| 1546 | 1546 | } |
| 1547 | 1547 | |
| 1548 | 1548 | // Verify invoice have an user |
| 1549 | - if ( false === $user || empty( $user ) ) { |
|
| 1549 | + if (false === $user || empty($user)) { |
|
| 1550 | 1550 | return false; |
| 1551 | 1551 | } |
| 1552 | 1552 | |
@@ -1563,11 +1563,11 @@ discard block |
||
| 1563 | 1563 | 'zip', |
| 1564 | 1564 | ); |
| 1565 | 1565 | |
| 1566 | - foreach ( $address_fields as $field ) { |
|
| 1567 | - $user[$field] = !empty( $_POST['wpinv_' . $field] ) ? sanitize_text_field( $_POST['wpinv_' . $field] ) : false; |
|
| 1566 | + foreach ($address_fields as $field) { |
|
| 1567 | + $user[$field] = !empty($_POST['wpinv_' . $field]) ? sanitize_text_field($_POST['wpinv_' . $field]) : false; |
|
| 1568 | 1568 | |
| 1569 | - if ( !empty( $user['user_id'] ) && !empty( $valid_data['current_user']['user_id'] ) && $valid_data['current_user']['user_id'] == $valid_data['invoice_user']['user_id'] ) { |
|
| 1570 | - update_user_meta( $user['user_id'], '_wpinv_' . $field, $user[$field] ); |
|
| 1569 | + if (!empty($user['user_id']) && !empty($valid_data['current_user']['user_id']) && $valid_data['current_user']['user_id'] == $valid_data['invoice_user']['user_id']) { |
|
| 1570 | + update_user_meta($user['user_id'], '_wpinv_' . $field, $user[$field]); |
|
| 1571 | 1571 | } |
| 1572 | 1572 | } |
| 1573 | 1573 | |
@@ -1575,26 +1575,26 @@ discard block |
||
| 1575 | 1575 | return $user; |
| 1576 | 1576 | } |
| 1577 | 1577 | |
| 1578 | -function wpinv_set_checkout_session( $invoice_data = array() ) { |
|
| 1578 | +function wpinv_set_checkout_session($invoice_data = array()) { |
|
| 1579 | 1579 | global $wpi_session; |
| 1580 | - return $wpi_session->set( 'wpinv_checkout', $invoice_data ); |
|
| 1580 | + return $wpi_session->set('wpinv_checkout', $invoice_data); |
|
| 1581 | 1581 | } |
| 1582 | 1582 | |
| 1583 | 1583 | function wpinv_get_checkout_session() { |
| 1584 | 1584 | global $wpi_session; |
| 1585 | - return $wpi_session->get( 'wpinv_checkout' ); |
|
| 1585 | + return $wpi_session->get('wpinv_checkout'); |
|
| 1586 | 1586 | } |
| 1587 | 1587 | |
| 1588 | 1588 | function wpinv_empty_cart() { |
| 1589 | 1589 | global $wpi_session; |
| 1590 | 1590 | |
| 1591 | 1591 | // Remove cart contents |
| 1592 | - $wpi_session->set( 'wpinv_checkout', NULL ); |
|
| 1592 | + $wpi_session->set('wpinv_checkout', NULL); |
|
| 1593 | 1593 | |
| 1594 | 1594 | // Remove all cart fees |
| 1595 | - $wpi_session->set( 'wpi_cart_fees', NULL ); |
|
| 1595 | + $wpi_session->set('wpi_cart_fees', NULL); |
|
| 1596 | 1596 | |
| 1597 | - do_action( 'wpinv_empty_cart' ); |
|
| 1597 | + do_action('wpinv_empty_cart'); |
|
| 1598 | 1598 | } |
| 1599 | 1599 | |
| 1600 | 1600 | function wpinv_process_checkout() { |
@@ -1603,7 +1603,7 @@ discard block |
||
| 1603 | 1603 | wpinv_clear_errors(); |
| 1604 | 1604 | |
| 1605 | 1605 | $invoice = wpinv_get_invoice_cart(); |
| 1606 | - if ( empty( $invoice ) ) { |
|
| 1606 | + if (empty($invoice)) { |
|
| 1607 | 1607 | return false; |
| 1608 | 1608 | } |
| 1609 | 1609 | |
@@ -1611,42 +1611,42 @@ discard block |
||
| 1611 | 1611 | |
| 1612 | 1612 | $wpi_checkout_id = $invoice->ID; |
| 1613 | 1613 | |
| 1614 | - do_action( 'wpinv_pre_process_checkout' ); |
|
| 1614 | + do_action('wpinv_pre_process_checkout'); |
|
| 1615 | 1615 | |
| 1616 | - if ( !wpinv_get_cart_contents() ) { // Make sure the cart isn't empty |
|
| 1616 | + if (!wpinv_get_cart_contents()) { // Make sure the cart isn't empty |
|
| 1617 | 1617 | $valid_data = false; |
| 1618 | - wpinv_set_error( 'empty_cart', __( 'Your cart is empty', 'invoicing' ) ); |
|
| 1618 | + wpinv_set_error('empty_cart', __('Your cart is empty', 'invoicing')); |
|
| 1619 | 1619 | } else { |
| 1620 | 1620 | // Validate the form $_POST data |
| 1621 | 1621 | $valid_data = wpinv_validate_checkout_fields(); |
| 1622 | 1622 | |
| 1623 | 1623 | // Allow themes and plugins to hook to errors |
| 1624 | - do_action( 'wpinv_checkout_error_checks', $valid_data, $_POST ); |
|
| 1624 | + do_action('wpinv_checkout_error_checks', $valid_data, $_POST); |
|
| 1625 | 1625 | } |
| 1626 | 1626 | |
| 1627 | - $is_ajax = defined( 'DOING_AJAX' ) && DOING_AJAX; |
|
| 1627 | + $is_ajax = defined('DOING_AJAX') && DOING_AJAX; |
|
| 1628 | 1628 | |
| 1629 | 1629 | // Validate the user |
| 1630 | - $user = wpinv_checkout_form_get_user( $valid_data ); |
|
| 1630 | + $user = wpinv_checkout_form_get_user($valid_data); |
|
| 1631 | 1631 | |
| 1632 | 1632 | // Let extensions validate fields after user is logged in if user has used login/registration form |
| 1633 | - do_action( 'wpinv_checkout_user_error_checks', $user, $valid_data, $_POST ); |
|
| 1633 | + do_action('wpinv_checkout_user_error_checks', $user, $valid_data, $_POST); |
|
| 1634 | 1634 | |
| 1635 | - if ( false === $valid_data || wpinv_get_errors() || ! $user ) { |
|
| 1636 | - if ( $is_ajax && 'wpinv_payment_form' != $_REQUEST['action'] ) { |
|
| 1637 | - do_action( 'wpinv_ajax_checkout_errors' ); |
|
| 1635 | + if (false === $valid_data || wpinv_get_errors() || !$user) { |
|
| 1636 | + if ($is_ajax && 'wpinv_payment_form' != $_REQUEST['action']) { |
|
| 1637 | + do_action('wpinv_ajax_checkout_errors'); |
|
| 1638 | 1638 | die(); |
| 1639 | 1639 | } else { |
| 1640 | 1640 | return false; |
| 1641 | 1641 | } |
| 1642 | 1642 | } |
| 1643 | 1643 | |
| 1644 | - if ( $is_ajax && 'wpinv_payment_form' != $_REQUEST['action'] ) { |
|
| 1644 | + if ($is_ajax && 'wpinv_payment_form' != $_REQUEST['action']) { |
|
| 1645 | 1645 | // Save address fields. |
| 1646 | - $address_fields = array( 'first_name', 'last_name', 'phone', 'address', 'city', 'country', 'state', 'zip', 'company' ); |
|
| 1647 | - foreach ( $address_fields as $field ) { |
|
| 1648 | - if ( isset( $user[$field] ) ) { |
|
| 1649 | - $invoice->set( $field, $user[$field] ); |
|
| 1646 | + $address_fields = array('first_name', 'last_name', 'phone', 'address', 'city', 'country', 'state', 'zip', 'company'); |
|
| 1647 | + foreach ($address_fields as $field) { |
|
| 1648 | + if (isset($user[$field])) { |
|
| 1649 | + $invoice->set($field, $user[$field]); |
|
| 1650 | 1650 | } |
| 1651 | 1651 | |
| 1652 | 1652 | $invoice->save(); |
@@ -1654,16 +1654,16 @@ discard block |
||
| 1654 | 1654 | |
| 1655 | 1655 | $response['success'] = true; |
| 1656 | 1656 | $response['data']['subtotal'] = $invoice->get_subtotal(); |
| 1657 | - $response['data']['subtotalf'] = $invoice->get_subtotal( true ); |
|
| 1657 | + $response['data']['subtotalf'] = $invoice->get_subtotal(true); |
|
| 1658 | 1658 | $response['data']['discount'] = $invoice->get_discount(); |
| 1659 | - $response['data']['discountf'] = $invoice->get_discount( true ); |
|
| 1659 | + $response['data']['discountf'] = $invoice->get_discount(true); |
|
| 1660 | 1660 | $response['data']['tax'] = $invoice->get_tax(); |
| 1661 | - $response['data']['taxf'] = $invoice->get_tax( true ); |
|
| 1661 | + $response['data']['taxf'] = $invoice->get_tax(true); |
|
| 1662 | 1662 | $response['data']['total'] = $invoice->get_total(); |
| 1663 | - $response['data']['totalf'] = $invoice->get_total( true ); |
|
| 1664 | - $response['data']['free'] = $invoice->is_free() && ( ! ( (float) $response['data']['total'] > 0 ) || $invoice->is_free_trial() ) ? true : false; |
|
| 1663 | + $response['data']['totalf'] = $invoice->get_total(true); |
|
| 1664 | + $response['data']['free'] = $invoice->is_free() && (!((float) $response['data']['total'] > 0) || $invoice->is_free_trial()) ? true : false; |
|
| 1665 | 1665 | |
| 1666 | - wp_send_json( $response ); |
|
| 1666 | + wp_send_json($response); |
|
| 1667 | 1667 | } |
| 1668 | 1668 | |
| 1669 | 1669 | $user_info = array( |
@@ -1685,42 +1685,42 @@ discard block |
||
| 1685 | 1685 | |
| 1686 | 1686 | // Setup invoice information |
| 1687 | 1687 | $invoice_data = array( |
| 1688 | - 'invoice_id' => !empty( $invoice ) ? $invoice->ID : 0, |
|
| 1688 | + 'invoice_id' => !empty($invoice) ? $invoice->ID : 0, |
|
| 1689 | 1689 | 'items' => $cart_items, |
| 1690 | 1690 | 'cart_discounts' => $discounts, |
| 1691 | - 'fees' => wpinv_get_cart_fees(), // Any arbitrary fees that have been added to the cart |
|
| 1692 | - 'subtotal' => wpinv_get_cart_subtotal( $cart_items ), // Amount before taxes and discounts |
|
| 1693 | - 'discount' => wpinv_get_cart_items_discount_amount( $cart_items, $discounts ), // Discounted amount |
|
| 1694 | - 'tax' => wpinv_get_cart_tax( $cart_items, $invoice ), // Taxed amount |
|
| 1695 | - 'price' => wpinv_get_cart_total( $cart_items, $discounts ), // Amount after taxes |
|
| 1691 | + 'fees' => wpinv_get_cart_fees(), // Any arbitrary fees that have been added to the cart |
|
| 1692 | + 'subtotal' => wpinv_get_cart_subtotal($cart_items), // Amount before taxes and discounts |
|
| 1693 | + 'discount' => wpinv_get_cart_items_discount_amount($cart_items, $discounts), // Discounted amount |
|
| 1694 | + 'tax' => wpinv_get_cart_tax($cart_items, $invoice), // Taxed amount |
|
| 1695 | + 'price' => wpinv_get_cart_total($cart_items, $discounts), // Amount after taxes |
|
| 1696 | 1696 | 'invoice_key' => $invoice->get_key() ? $invoice->get_key() : $invoice->generate_key(), |
| 1697 | 1697 | 'user_email' => $invoice->get_email(), |
| 1698 | - 'date' => date( 'Y-m-d H:i:s', current_time( 'timestamp' ) ), |
|
| 1699 | - 'user_info' => stripslashes_deep( $user_info ), |
|
| 1698 | + 'date' => date('Y-m-d H:i:s', current_time('timestamp')), |
|
| 1699 | + 'user_info' => stripslashes_deep($user_info), |
|
| 1700 | 1700 | 'post_data' => $_POST, |
| 1701 | 1701 | 'cart_details' => $cart_items, |
| 1702 | 1702 | 'gateway' => $valid_data['gateway'], |
| 1703 | 1703 | 'card_info' => $valid_data['cc_info'] |
| 1704 | 1704 | ); |
| 1705 | 1705 | |
| 1706 | - $vat_info = $wpinv_euvat->current_vat_data(); |
|
| 1707 | - if ( is_array( $vat_info ) ) { |
|
| 1706 | + $vat_info = $wpinv_euvat->current_vat_data(); |
|
| 1707 | + if (is_array($vat_info)) { |
|
| 1708 | 1708 | $invoice_data['user_info']['vat_number'] = $vat_info['number']; |
| 1709 | 1709 | $invoice_data['user_info']['vat_rate'] = wpinv_get_tax_rate($invoice_data['user_info']['country'], $invoice_data['user_info']['state']); |
| 1710 | - $invoice_data['user_info']['adddress_confirmed'] = isset($vat_info['adddress_confirmed']) ? $vat_info['adddress_confirmed'] : false; |
|
| 1710 | + $invoice_data['user_info']['adddress_confirmed'] = isset($vat_info['adddress_confirmed']) ? $vat_info['adddress_confirmed'] : false; |
|
| 1711 | 1711 | |
| 1712 | 1712 | // Add the VAT rate to each item in the cart |
| 1713 | - foreach( $invoice_data['cart_details'] as $key => $item_data) { |
|
| 1713 | + foreach ($invoice_data['cart_details'] as $key => $item_data) { |
|
| 1714 | 1714 | $rate = wpinv_get_tax_rate($invoice_data['user_info']['country'], $invoice_data['user_info']['state'], $item_data['id']); |
| 1715 | - $invoice_data['cart_details'][$key]['vat_rate'] = wpinv_round_amount( $rate, 4 ); |
|
| 1715 | + $invoice_data['cart_details'][$key]['vat_rate'] = wpinv_round_amount($rate, 4); |
|
| 1716 | 1716 | } |
| 1717 | 1717 | } |
| 1718 | 1718 | |
| 1719 | 1719 | // Save vat fields. |
| 1720 | - $address_fields = array( 'vat_number', 'vat_rate', 'adddress_confirmed' ); |
|
| 1721 | - foreach ( $address_fields as $field ) { |
|
| 1722 | - if ( isset( $invoice_data['user_info'][$field] ) ) { |
|
| 1723 | - $invoice->set( $field, $invoice_data['user_info'][$field] ); |
|
| 1720 | + $address_fields = array('vat_number', 'vat_rate', 'adddress_confirmed'); |
|
| 1721 | + foreach ($address_fields as $field) { |
|
| 1722 | + if (isset($invoice_data['user_info'][$field])) { |
|
| 1723 | + $invoice->set($field, $invoice_data['user_info'][$field]); |
|
| 1724 | 1724 | } |
| 1725 | 1725 | } |
| 1726 | 1726 | $invoice->save(); |
@@ -1729,54 +1729,54 @@ discard block |
||
| 1729 | 1729 | $valid_data['user'] = $user; |
| 1730 | 1730 | |
| 1731 | 1731 | // Allow themes and plugins to hook before the gateway |
| 1732 | - do_action( 'wpinv_checkout_before_gateway', $_POST, $user_info, $valid_data ); |
|
| 1732 | + do_action('wpinv_checkout_before_gateway', $_POST, $user_info, $valid_data); |
|
| 1733 | 1733 | |
| 1734 | 1734 | // If it is free, abort. |
| 1735 | - if ( $invoice->is_free() && ( ! $invoice->is_recurring() || 0 == $invoice->get_recurring_details( 'total' ) ) ) { |
|
| 1735 | + if ($invoice->is_free() && (!$invoice->is_recurring() || 0 == $invoice->get_recurring_details('total'))) { |
|
| 1736 | 1736 | $invoice_data['gateway'] = 'manual'; |
| 1737 | 1737 | $_POST['wpi-gateway'] = 'manual'; |
| 1738 | 1738 | } |
| 1739 | 1739 | |
| 1740 | 1740 | // Allow the invoice data to be modified before it is sent to the gateway |
| 1741 | - $invoice_data = apply_filters( 'wpinv_data_before_gateway', $invoice_data, $valid_data ); |
|
| 1741 | + $invoice_data = apply_filters('wpinv_data_before_gateway', $invoice_data, $valid_data); |
|
| 1742 | 1742 | |
| 1743 | - if ( $invoice_data['price'] && $invoice_data['gateway'] == 'manual' ) { |
|
| 1743 | + if ($invoice_data['price'] && $invoice_data['gateway'] == 'manual') { |
|
| 1744 | 1744 | $mode = 'test'; |
| 1745 | 1745 | } else { |
| 1746 | - $mode = wpinv_is_test_mode( $invoice_data['gateway'] ) ? 'test' : 'live'; |
|
| 1746 | + $mode = wpinv_is_test_mode($invoice_data['gateway']) ? 'test' : 'live'; |
|
| 1747 | 1747 | } |
| 1748 | 1748 | |
| 1749 | 1749 | // Setup the data we're storing in the purchase session |
| 1750 | 1750 | $session_data = $invoice_data; |
| 1751 | 1751 | // Make sure credit card numbers are never stored in sessions |
| 1752 | - if ( !empty( $session_data['card_info']['card_number'] ) ) { |
|
| 1753 | - unset( $session_data['card_info']['card_number'] ); |
|
| 1752 | + if (!empty($session_data['card_info']['card_number'])) { |
|
| 1753 | + unset($session_data['card_info']['card_number']); |
|
| 1754 | 1754 | } |
| 1755 | 1755 | |
| 1756 | 1756 | // Used for showing item links to non logged-in users after purchase, and for other plugins needing purchase data. |
| 1757 | - wpinv_set_checkout_session( $invoice_data ); |
|
| 1757 | + wpinv_set_checkout_session($invoice_data); |
|
| 1758 | 1758 | |
| 1759 | 1759 | // Set gateway |
| 1760 | - $invoice->update_meta( '_wpinv_gateway', $invoice_data['gateway'] ); |
|
| 1761 | - $invoice->update_meta( '_wpinv_mode', $mode ); |
|
| 1762 | - $invoice->update_meta( '_wpinv_checkout', date_i18n( 'Y-m-d H:i:s', current_time( 'timestamp' ) ) ); |
|
| 1760 | + $invoice->update_meta('_wpinv_gateway', $invoice_data['gateway']); |
|
| 1761 | + $invoice->update_meta('_wpinv_mode', $mode); |
|
| 1762 | + $invoice->update_meta('_wpinv_checkout', date_i18n('Y-m-d H:i:s', current_time('timestamp'))); |
|
| 1763 | 1763 | |
| 1764 | - do_action( 'wpinv_checkout_before_send_to_gateway', $invoice, $invoice_data ); |
|
| 1764 | + do_action('wpinv_checkout_before_send_to_gateway', $invoice, $invoice_data); |
|
| 1765 | 1765 | |
| 1766 | 1766 | // Send info to the gateway for payment processing |
| 1767 | - wpinv_send_to_gateway( $invoice_data['gateway'], $invoice_data ); |
|
| 1767 | + wpinv_send_to_gateway($invoice_data['gateway'], $invoice_data); |
|
| 1768 | 1768 | die(); |
| 1769 | 1769 | } |
| 1770 | -add_action( 'wpinv_payment', 'wpinv_process_checkout' ); |
|
| 1770 | +add_action('wpinv_payment', 'wpinv_process_checkout'); |
|
| 1771 | 1771 | |
| 1772 | -function wpinv_get_invoices( $args ) { |
|
| 1773 | - $args = wp_parse_args( $args, array( |
|
| 1774 | - 'status' => array_keys( wpinv_get_invoice_statuses() ), |
|
| 1772 | +function wpinv_get_invoices($args) { |
|
| 1773 | + $args = wp_parse_args($args, array( |
|
| 1774 | + 'status' => array_keys(wpinv_get_invoice_statuses()), |
|
| 1775 | 1775 | 'type' => 'wpi_invoice', |
| 1776 | 1776 | 'parent' => null, |
| 1777 | 1777 | 'user' => null, |
| 1778 | 1778 | 'email' => '', |
| 1779 | - 'limit' => get_option( 'posts_per_page' ), |
|
| 1779 | + 'limit' => get_option('posts_per_page'), |
|
| 1780 | 1780 | 'offset' => null, |
| 1781 | 1781 | 'page' => 1, |
| 1782 | 1782 | 'exclude' => array(), |
@@ -1784,7 +1784,7 @@ discard block |
||
| 1784 | 1784 | 'order' => 'DESC', |
| 1785 | 1785 | 'return' => 'objects', |
| 1786 | 1786 | 'paginate' => false, |
| 1787 | - ) ); |
|
| 1787 | + )); |
|
| 1788 | 1788 | |
| 1789 | 1789 | // Handle some BW compatibility arg names where wp_query args differ in naming. |
| 1790 | 1790 | $map_legacy = array( |
@@ -1797,18 +1797,18 @@ discard block |
||
| 1797 | 1797 | 'paged' => 'page', |
| 1798 | 1798 | ); |
| 1799 | 1799 | |
| 1800 | - foreach ( $map_legacy as $from => $to ) { |
|
| 1801 | - if ( isset( $args[ $from ] ) ) { |
|
| 1802 | - $args[ $to ] = $args[ $from ]; |
|
| 1800 | + foreach ($map_legacy as $from => $to) { |
|
| 1801 | + if (isset($args[$from])) { |
|
| 1802 | + $args[$to] = $args[$from]; |
|
| 1803 | 1803 | } |
| 1804 | 1804 | } |
| 1805 | 1805 | |
| 1806 | - if ( get_query_var( 'paged' ) ) |
|
| 1806 | + if (get_query_var('paged')) |
|
| 1807 | 1807 | $args['page'] = get_query_var('paged'); |
| 1808 | - else if ( get_query_var( 'page' ) ) |
|
| 1809 | - $args['page'] = get_query_var( 'page' ); |
|
| 1810 | - else if ( !empty( $args[ 'page' ] ) ) |
|
| 1811 | - $args['page'] = $args[ 'page' ]; |
|
| 1808 | + else if (get_query_var('page')) |
|
| 1809 | + $args['page'] = get_query_var('page'); |
|
| 1810 | + else if (!empty($args['page'])) |
|
| 1811 | + $args['page'] = $args['page']; |
|
| 1812 | 1812 | else |
| 1813 | 1813 | $args['page'] = 1; |
| 1814 | 1814 | |
@@ -1821,48 +1821,48 @@ discard block |
||
| 1821 | 1821 | 'post_status' => $args['status'], |
| 1822 | 1822 | 'posts_per_page' => $args['limit'], |
| 1823 | 1823 | 'meta_query' => array(), |
| 1824 | - 'date_query' => !empty( $args['date_query'] ) ? $args['date_query'] : array(), |
|
| 1824 | + 'date_query' => !empty($args['date_query']) ? $args['date_query'] : array(), |
|
| 1825 | 1825 | 'fields' => 'ids', |
| 1826 | 1826 | 'orderby' => $args['orderby'], |
| 1827 | 1827 | 'order' => $args['order'], |
| 1828 | 1828 | ); |
| 1829 | 1829 | |
| 1830 | - if ( !empty( $args['user'] ) ) { |
|
| 1831 | - $wp_query_args['author'] = absint( $args['user'] ); |
|
| 1830 | + if (!empty($args['user'])) { |
|
| 1831 | + $wp_query_args['author'] = absint($args['user']); |
|
| 1832 | 1832 | } |
| 1833 | 1833 | |
| 1834 | - if ( ! is_null( $args['parent'] ) ) { |
|
| 1835 | - $wp_query_args['post_parent'] = absint( $args['parent'] ); |
|
| 1834 | + if (!is_null($args['parent'])) { |
|
| 1835 | + $wp_query_args['post_parent'] = absint($args['parent']); |
|
| 1836 | 1836 | } |
| 1837 | 1837 | |
| 1838 | - if ( ! is_null( $args['offset'] ) ) { |
|
| 1839 | - $wp_query_args['offset'] = absint( $args['offset'] ); |
|
| 1838 | + if (!is_null($args['offset'])) { |
|
| 1839 | + $wp_query_args['offset'] = absint($args['offset']); |
|
| 1840 | 1840 | } else { |
| 1841 | - $wp_query_args['paged'] = absint( $args['page'] ); |
|
| 1841 | + $wp_query_args['paged'] = absint($args['page']); |
|
| 1842 | 1842 | } |
| 1843 | 1843 | |
| 1844 | - if ( ! empty( $args['exclude'] ) ) { |
|
| 1845 | - $wp_query_args['post__not_in'] = array_map( 'absint', $args['exclude'] ); |
|
| 1844 | + if (!empty($args['exclude'])) { |
|
| 1845 | + $wp_query_args['post__not_in'] = array_map('absint', $args['exclude']); |
|
| 1846 | 1846 | } |
| 1847 | 1847 | |
| 1848 | - if ( ! $args['paginate' ] ) { |
|
| 1848 | + if (!$args['paginate']) { |
|
| 1849 | 1849 | $wp_query_args['no_found_rows'] = true; |
| 1850 | 1850 | } |
| 1851 | 1851 | |
| 1852 | 1852 | $wp_query_args = apply_filters('wpinv_get_invoices_args', $wp_query_args, $args); |
| 1853 | 1853 | |
| 1854 | 1854 | // Get results. |
| 1855 | - $invoices = new WP_Query( $wp_query_args ); |
|
| 1855 | + $invoices = new WP_Query($wp_query_args); |
|
| 1856 | 1856 | |
| 1857 | - if ( 'objects' === $args['return'] ) { |
|
| 1858 | - $return = array_map( 'wpinv_get_invoice', $invoices->posts ); |
|
| 1859 | - } elseif ( 'self' === $args['return'] ) { |
|
| 1857 | + if ('objects' === $args['return']) { |
|
| 1858 | + $return = array_map('wpinv_get_invoice', $invoices->posts); |
|
| 1859 | + } elseif ('self' === $args['return']) { |
|
| 1860 | 1860 | return $invoices; |
| 1861 | 1861 | } else { |
| 1862 | 1862 | $return = $invoices->posts; |
| 1863 | 1863 | } |
| 1864 | 1864 | |
| 1865 | - if ( $args['paginate' ] ) { |
|
| 1865 | + if ($args['paginate']) { |
|
| 1866 | 1866 | return (object) array( |
| 1867 | 1867 | 'invoices' => $return, |
| 1868 | 1868 | 'total' => $invoices->found_posts, |
@@ -1875,22 +1875,22 @@ discard block |
||
| 1875 | 1875 | |
| 1876 | 1876 | function wpinv_get_user_invoices_columns() { |
| 1877 | 1877 | $columns = array( |
| 1878 | - 'invoice-number' => array( 'title' => __( 'ID', 'invoicing' ), 'class' => 'text-left' ), |
|
| 1879 | - 'created-date' => array( 'title' => __( 'Created Date', 'invoicing' ), 'class' => 'text-left' ), |
|
| 1880 | - 'payment-date' => array( 'title' => __( 'Payment Date', 'invoicing' ), 'class' => 'text-left' ), |
|
| 1881 | - 'invoice-status' => array( 'title' => __( 'Status', 'invoicing' ), 'class' => 'text-center' ), |
|
| 1882 | - 'invoice-total' => array( 'title' => __( 'Total', 'invoicing' ), 'class' => 'text-right' ), |
|
| 1883 | - 'invoice-actions' => array( 'title' => ' ', 'class' => 'text-center' ), |
|
| 1878 | + 'invoice-number' => array('title' => __('ID', 'invoicing'), 'class' => 'text-left'), |
|
| 1879 | + 'created-date' => array('title' => __('Created Date', 'invoicing'), 'class' => 'text-left'), |
|
| 1880 | + 'payment-date' => array('title' => __('Payment Date', 'invoicing'), 'class' => 'text-left'), |
|
| 1881 | + 'invoice-status' => array('title' => __('Status', 'invoicing'), 'class' => 'text-center'), |
|
| 1882 | + 'invoice-total' => array('title' => __('Total', 'invoicing'), 'class' => 'text-right'), |
|
| 1883 | + 'invoice-actions' => array('title' => ' ', 'class' => 'text-center'), |
|
| 1884 | 1884 | ); |
| 1885 | 1885 | |
| 1886 | - return apply_filters( 'wpinv_user_invoices_columns', $columns ); |
|
| 1886 | + return apply_filters('wpinv_user_invoices_columns', $columns); |
|
| 1887 | 1887 | } |
| 1888 | 1888 | |
| 1889 | -function wpinv_payment_receipt( $atts, $content = null ) { |
|
| 1889 | +function wpinv_payment_receipt($atts, $content = null) { |
|
| 1890 | 1890 | global $wpinv_receipt_args; |
| 1891 | 1891 | |
| 1892 | - $wpinv_receipt_args = shortcode_atts( array( |
|
| 1893 | - 'error' => __( 'Sorry, trouble retrieving payment receipt.', 'invoicing' ), |
|
| 1892 | + $wpinv_receipt_args = shortcode_atts(array( |
|
| 1893 | + 'error' => __('Sorry, trouble retrieving payment receipt.', 'invoicing'), |
|
| 1894 | 1894 | 'price' => true, |
| 1895 | 1895 | 'discount' => true, |
| 1896 | 1896 | 'items' => true, |
@@ -1899,45 +1899,45 @@ discard block |
||
| 1899 | 1899 | 'invoice_key' => false, |
| 1900 | 1900 | 'payment_method' => true, |
| 1901 | 1901 | 'invoice_id' => true |
| 1902 | - ), $atts, 'wpinv_receipt' ); |
|
| 1902 | + ), $atts, 'wpinv_receipt'); |
|
| 1903 | 1903 | |
| 1904 | 1904 | // Find the invoice. |
| 1905 | 1905 | $session = wpinv_get_checkout_session(); |
| 1906 | 1906 | |
| 1907 | - if ( isset( $_GET['invoice_key'] ) ) { |
|
| 1908 | - $invoice_id = wpinv_get_invoice_id_by_key( urldecode( $_GET['invoice_key'] ) ); |
|
| 1909 | - } else if ( isset( $_GET['invoice-id'] ) ) { |
|
| 1907 | + if (isset($_GET['invoice_key'])) { |
|
| 1908 | + $invoice_id = wpinv_get_invoice_id_by_key(urldecode($_GET['invoice_key'])); |
|
| 1909 | + } else if (isset($_GET['invoice-id'])) { |
|
| 1910 | 1910 | $invoice_id = (int) $_GET['invoice-id']; |
| 1911 | - } else if ( $session && isset( $session['invoice_key'] ) ) { |
|
| 1912 | - $invoice_id = wpinv_get_invoice_id_by_key( $session['invoice_key'] ); |
|
| 1913 | - } else if ( isset( $wpinv_receipt_args['invoice_key'] ) && $wpinv_receipt_args['invoice_key'] ) { |
|
| 1914 | - $invoice_id = wpinv_get_invoice_id_by_key( $wpinv_receipt_args['invoice_key'] ); |
|
| 1911 | + } else if ($session && isset($session['invoice_key'])) { |
|
| 1912 | + $invoice_id = wpinv_get_invoice_id_by_key($session['invoice_key']); |
|
| 1913 | + } else if (isset($wpinv_receipt_args['invoice_key']) && $wpinv_receipt_args['invoice_key']) { |
|
| 1914 | + $invoice_id = wpinv_get_invoice_id_by_key($wpinv_receipt_args['invoice_key']); |
|
| 1915 | 1915 | } |
| 1916 | 1916 | |
| 1917 | 1917 | // Did we find the invoice? |
| 1918 | - if ( empty( $invoice_id ) || ! $invoice = wpinv_get_invoice( $invoice_id ) ) { |
|
| 1919 | - return '<p class="alert alert-error">' . __( 'We could not find your invoice.', 'invoicing' ) . '</p>'; |
|
| 1918 | + if (empty($invoice_id) || !$invoice = wpinv_get_invoice($invoice_id)) { |
|
| 1919 | + return '<p class="alert alert-error">' . __('We could not find your invoice.', 'invoicing') . '</p>'; |
|
| 1920 | 1920 | } |
| 1921 | 1921 | |
| 1922 | 1922 | $invoice_key = $invoice->get_key(); |
| 1923 | - $user_can_view = wpinv_can_view_receipt( $invoice_key ); |
|
| 1924 | - if ( $user_can_view && isset( $_GET['invoice-id'] ) ) { |
|
| 1925 | - $user_can_view = $_GET['invoice-id'] == $invoice->ID; |
|
| 1923 | + $user_can_view = wpinv_can_view_receipt($invoice_key); |
|
| 1924 | + if ($user_can_view && isset($_GET['invoice-id'])) { |
|
| 1925 | + $user_can_view = $_GET['invoice-id'] == $invoice->ID; |
|
| 1926 | 1926 | } |
| 1927 | 1927 | |
| 1928 | 1928 | // Key was provided, but user is logged out. Offer them the ability to login and view the receipt |
| 1929 | - if ( ! $user_can_view && ! empty( $invoice_key ) && ! is_user_logged_in() ) { |
|
| 1929 | + if (!$user_can_view && !empty($invoice_key) && !is_user_logged_in()) { |
|
| 1930 | 1930 | // login redirect |
| 1931 | - return '<p class="alert alert-error">' . __( 'You must be logged in to view this receipt', 'invoicing' ) . '</p>'; |
|
| 1931 | + return '<p class="alert alert-error">' . __('You must be logged in to view this receipt', 'invoicing') . '</p>'; |
|
| 1932 | 1932 | } |
| 1933 | 1933 | |
| 1934 | - if ( ! apply_filters( 'wpinv_user_can_view_receipt', $user_can_view, $wpinv_receipt_args ) ) { |
|
| 1934 | + if (!apply_filters('wpinv_user_can_view_receipt', $user_can_view, $wpinv_receipt_args)) { |
|
| 1935 | 1935 | return '<p class="alert alert-error">' . $wpinv_receipt_args['error'] . '</p>'; |
| 1936 | 1936 | } |
| 1937 | 1937 | |
| 1938 | 1938 | ob_start(); |
| 1939 | 1939 | |
| 1940 | - wpinv_get_template_part( 'wpinv-invoice-receipt' ); |
|
| 1940 | + wpinv_get_template_part('wpinv-invoice-receipt'); |
|
| 1941 | 1941 | |
| 1942 | 1942 | $display = ob_get_clean(); |
| 1943 | 1943 | |
@@ -1947,148 +1947,148 @@ discard block |
||
| 1947 | 1947 | /** |
| 1948 | 1948 | * Given an invoice key, this function returns the id. |
| 1949 | 1949 | */ |
| 1950 | -function wpinv_get_invoice_id_by_key( $key ) { |
|
| 1950 | +function wpinv_get_invoice_id_by_key($key) { |
|
| 1951 | 1951 | global $wpdb; |
| 1952 | - $table = $wpdb->prefix . 'getpaid_invoices'; |
|
| 1953 | - return (int) $wpdb->get_var( $wpdb->prepare( "SELECT post_id FROM $table WHERE`key` = %s LIMIT 1", $key ) ); |
|
| 1952 | + $table = $wpdb->prefix . 'getpaid_invoices'; |
|
| 1953 | + return (int) $wpdb->get_var($wpdb->prepare("SELECT post_id FROM $table WHERE`key` = %s LIMIT 1", $key)); |
|
| 1954 | 1954 | } |
| 1955 | 1955 | |
| 1956 | -function wpinv_can_view_receipt( $invoice_key = '' ) { |
|
| 1957 | - $return = current_user_can( 'manage_options' ); |
|
| 1956 | +function wpinv_can_view_receipt($invoice_key = '') { |
|
| 1957 | + $return = current_user_can('manage_options'); |
|
| 1958 | 1958 | |
| 1959 | - if ( empty( $invoice_key ) ) { |
|
| 1959 | + if (empty($invoice_key)) { |
|
| 1960 | 1960 | return false; |
| 1961 | 1961 | } |
| 1962 | 1962 | |
| 1963 | 1963 | global $wpinv_receipt_args; |
| 1964 | 1964 | |
| 1965 | - $wpinv_receipt_args['id'] = wpinv_get_invoice_id_by_key( $invoice_key ); |
|
| 1966 | - if ( isset( $_GET['invoice-id'] ) ) { |
|
| 1967 | - $wpinv_receipt_args['id'] = $invoice_key == wpinv_get_payment_key( (int)$_GET['invoice-id'] ) ? (int)$_GET['invoice-id'] : 0; |
|
| 1965 | + $wpinv_receipt_args['id'] = wpinv_get_invoice_id_by_key($invoice_key); |
|
| 1966 | + if (isset($_GET['invoice-id'])) { |
|
| 1967 | + $wpinv_receipt_args['id'] = $invoice_key == wpinv_get_payment_key((int) $_GET['invoice-id']) ? (int) $_GET['invoice-id'] : 0; |
|
| 1968 | 1968 | } |
| 1969 | 1969 | |
| 1970 | - if ( empty( $wpinv_receipt_args['id'] ) ) { |
|
| 1970 | + if (empty($wpinv_receipt_args['id'])) { |
|
| 1971 | 1971 | return $return; |
| 1972 | 1972 | } |
| 1973 | 1973 | |
| 1974 | - $invoice = wpinv_get_invoice( $wpinv_receipt_args['id'] ); |
|
| 1975 | - if ( !( !empty( $invoice->ID ) && $invoice->get_key() === $invoice_key ) ) { |
|
| 1974 | + $invoice = wpinv_get_invoice($wpinv_receipt_args['id']); |
|
| 1975 | + if (!(!empty($invoice->ID) && $invoice->get_key() === $invoice_key)) { |
|
| 1976 | 1976 | return $return; |
| 1977 | 1977 | } |
| 1978 | 1978 | |
| 1979 | - if ( is_user_logged_in() ) { |
|
| 1980 | - if ( (int)$invoice->get_user_id() === (int) get_current_user_id() ) { |
|
| 1979 | + if (is_user_logged_in()) { |
|
| 1980 | + if ((int) $invoice->get_user_id() === (int) get_current_user_id()) { |
|
| 1981 | 1981 | $return = true; |
| 1982 | 1982 | } |
| 1983 | 1983 | } |
| 1984 | 1984 | |
| 1985 | 1985 | $session = wpinv_get_checkout_session(); |
| 1986 | - if ( isset( $_GET['invoice_key'] ) || ( $session && isset( $session['invoice_key'] ) ) ) { |
|
| 1987 | - $check_key = isset( $_GET['invoice_key'] ) ? $_GET['invoice_key'] : $session['invoice_key']; |
|
| 1986 | + if (isset($_GET['invoice_key']) || ($session && isset($session['invoice_key']))) { |
|
| 1987 | + $check_key = isset($_GET['invoice_key']) ? $_GET['invoice_key'] : $session['invoice_key']; |
|
| 1988 | 1988 | |
| 1989 | - if ( wpinv_require_login_to_checkout() ) { |
|
| 1989 | + if (wpinv_require_login_to_checkout()) { |
|
| 1990 | 1990 | $return = $return && $check_key == $invoice_key; |
| 1991 | 1991 | } else { |
| 1992 | 1992 | $return = $check_key == $invoice_key; |
| 1993 | 1993 | } |
| 1994 | 1994 | } |
| 1995 | 1995 | |
| 1996 | - return (bool) apply_filters( 'wpinv_can_view_receipt', $return, $invoice_key ); |
|
| 1996 | + return (bool) apply_filters('wpinv_can_view_receipt', $return, $invoice_key); |
|
| 1997 | 1997 | } |
| 1998 | 1998 | |
| 1999 | 1999 | function wpinv_pay_for_invoice() { |
| 2000 | 2000 | global $wpinv_euvat; |
| 2001 | 2001 | |
| 2002 | - if ( isset( $_GET['invoice_key'] ) ) { |
|
| 2002 | + if (isset($_GET['invoice_key'])) { |
|
| 2003 | 2003 | $checkout_uri = wpinv_get_checkout_uri(); |
| 2004 | - $invoice_key = sanitize_text_field( $_GET['invoice_key'] ); |
|
| 2004 | + $invoice_key = sanitize_text_field($_GET['invoice_key']); |
|
| 2005 | 2005 | |
| 2006 | - if ( empty( $invoice_key ) ) { |
|
| 2007 | - wpinv_set_error( 'invalid_invoice', __( 'Invoice not found', 'invoicing' ) ); |
|
| 2008 | - wp_redirect( $checkout_uri ); |
|
| 2006 | + if (empty($invoice_key)) { |
|
| 2007 | + wpinv_set_error('invalid_invoice', __('Invoice not found', 'invoicing')); |
|
| 2008 | + wp_redirect($checkout_uri); |
|
| 2009 | 2009 | exit(); |
| 2010 | 2010 | } |
| 2011 | 2011 | |
| 2012 | - do_action( 'wpinv_check_pay_for_invoice', $invoice_key ); |
|
| 2012 | + do_action('wpinv_check_pay_for_invoice', $invoice_key); |
|
| 2013 | 2013 | |
| 2014 | - $invoice_id = wpinv_get_invoice_id_by_key( $invoice_key ); |
|
| 2015 | - $user_can_view = wpinv_can_view_receipt( $invoice_key ); |
|
| 2016 | - if ( $user_can_view && isset( $_GET['invoice-id'] ) ) { |
|
| 2017 | - $invoice_id = (int)$_GET['invoice-id']; |
|
| 2018 | - $user_can_view = $invoice_key == wpinv_get_payment_key( (int)$_GET['invoice-id'] ) ? true : false; |
|
| 2014 | + $invoice_id = wpinv_get_invoice_id_by_key($invoice_key); |
|
| 2015 | + $user_can_view = wpinv_can_view_receipt($invoice_key); |
|
| 2016 | + if ($user_can_view && isset($_GET['invoice-id'])) { |
|
| 2017 | + $invoice_id = (int) $_GET['invoice-id']; |
|
| 2018 | + $user_can_view = $invoice_key == wpinv_get_payment_key((int) $_GET['invoice-id']) ? true : false; |
|
| 2019 | 2019 | } |
| 2020 | 2020 | |
| 2021 | - if ( $invoice_id && $user_can_view && ( $invoice = wpinv_get_invoice( $invoice_id ) ) ) { |
|
| 2022 | - if ( $invoice->needs_payment() ) { |
|
| 2021 | + if ($invoice_id && $user_can_view && ($invoice = wpinv_get_invoice($invoice_id))) { |
|
| 2022 | + if ($invoice->needs_payment()) { |
|
| 2023 | 2023 | $data = array(); |
| 2024 | 2024 | $data['invoice_id'] = $invoice_id; |
| 2025 | - $data['cart_discounts'] = $invoice->get_discounts( true ); |
|
| 2025 | + $data['cart_discounts'] = $invoice->get_discounts(true); |
|
| 2026 | 2026 | |
| 2027 | - wpinv_set_checkout_session( $data ); |
|
| 2027 | + wpinv_set_checkout_session($data); |
|
| 2028 | 2028 | |
| 2029 | - if ( wpinv_get_option( 'vat_ip_country_default' ) ) { |
|
| 2029 | + if (wpinv_get_option('vat_ip_country_default')) { |
|
| 2030 | 2030 | $_POST['country'] = $wpinv_euvat->get_country_by_ip(); |
| 2031 | 2031 | $_POST['state'] = $_POST['country'] == $invoice->country ? $invoice->state : ''; |
| 2032 | 2032 | |
| 2033 | - wpinv_recalculate_tax( true ); |
|
| 2033 | + wpinv_recalculate_tax(true); |
|
| 2034 | 2034 | } |
| 2035 | 2035 | |
| 2036 | 2036 | } else { |
| 2037 | 2037 | $checkout_uri = $invoice->get_view_url(); |
| 2038 | 2038 | } |
| 2039 | 2039 | } else { |
| 2040 | - wpinv_set_error( 'invalid_invoice', __( 'You are not allowed to view this invoice', 'invoicing' ) ); |
|
| 2040 | + wpinv_set_error('invalid_invoice', __('You are not allowed to view this invoice', 'invoicing')); |
|
| 2041 | 2041 | |
| 2042 | - $checkout_uri = is_user_logged_in() ? wpinv_get_history_page_uri() : wp_login_url( get_permalink() ); |
|
| 2042 | + $checkout_uri = is_user_logged_in() ? wpinv_get_history_page_uri() : wp_login_url(get_permalink()); |
|
| 2043 | 2043 | } |
| 2044 | 2044 | |
| 2045 | - if(wp_redirect( $checkout_uri )){ |
|
| 2045 | + if (wp_redirect($checkout_uri)) { |
|
| 2046 | 2046 | exit; |
| 2047 | 2047 | }; |
| 2048 | 2048 | wpinv_die(); |
| 2049 | 2049 | } |
| 2050 | 2050 | } |
| 2051 | -add_action( 'wpinv_pay_for_invoice', 'wpinv_pay_for_invoice' ); |
|
| 2051 | +add_action('wpinv_pay_for_invoice', 'wpinv_pay_for_invoice'); |
|
| 2052 | 2052 | |
| 2053 | -function wpinv_handle_pay_via_invoice_link( $invoice_key ) { |
|
| 2054 | - if ( !empty( $invoice_key ) && !empty( $_REQUEST['_wpipay'] ) && !is_user_logged_in() && $invoice_id = wpinv_get_invoice_id_by_key( $invoice_key ) ) { |
|
| 2055 | - if ( $invoice = wpinv_get_invoice( $invoice_id ) ) { |
|
| 2053 | +function wpinv_handle_pay_via_invoice_link($invoice_key) { |
|
| 2054 | + if (!empty($invoice_key) && !empty($_REQUEST['_wpipay']) && !is_user_logged_in() && $invoice_id = wpinv_get_invoice_id_by_key($invoice_key)) { |
|
| 2055 | + if ($invoice = wpinv_get_invoice($invoice_id)) { |
|
| 2056 | 2056 | $user_id = $invoice->get_user_id(); |
| 2057 | - $secret = sanitize_text_field( $_GET['_wpipay'] ); |
|
| 2057 | + $secret = sanitize_text_field($_GET['_wpipay']); |
|
| 2058 | 2058 | |
| 2059 | - if ( $secret === md5( $user_id . '::' . $invoice->get_email() . '::' . $invoice_key ) ) { // valid invoice link |
|
| 2060 | - $redirect_to = remove_query_arg( '_wpipay', get_permalink() ); |
|
| 2059 | + if ($secret === md5($user_id . '::' . $invoice->get_email() . '::' . $invoice_key)) { // valid invoice link |
|
| 2060 | + $redirect_to = remove_query_arg('_wpipay', get_permalink()); |
|
| 2061 | 2061 | |
| 2062 | - wpinv_guest_redirect( $redirect_to, $user_id ); |
|
| 2062 | + wpinv_guest_redirect($redirect_to, $user_id); |
|
| 2063 | 2063 | exit(); |
| 2064 | 2064 | } |
| 2065 | 2065 | } |
| 2066 | 2066 | } |
| 2067 | 2067 | } |
| 2068 | -add_action( 'wpinv_check_pay_for_invoice', 'wpinv_handle_pay_via_invoice_link' ); |
|
| 2068 | +add_action('wpinv_check_pay_for_invoice', 'wpinv_handle_pay_via_invoice_link'); |
|
| 2069 | 2069 | |
| 2070 | -function wpinv_set_payment_transaction_id( $invoice_id = 0, $transaction_id = '' ) { |
|
| 2071 | - $invoice_id = is_object( $invoice_id ) && !empty( $invoice_id->ID ) ? $invoice_id : $invoice_id; |
|
| 2070 | +function wpinv_set_payment_transaction_id($invoice_id = 0, $transaction_id = '') { |
|
| 2071 | + $invoice_id = is_object($invoice_id) && !empty($invoice_id->ID) ? $invoice_id : $invoice_id; |
|
| 2072 | 2072 | |
| 2073 | - if ( empty( $invoice_id ) && $invoice_id > 0 ) { |
|
| 2073 | + if (empty($invoice_id) && $invoice_id > 0) { |
|
| 2074 | 2074 | return false; |
| 2075 | 2075 | } |
| 2076 | 2076 | |
| 2077 | - if ( empty( $transaction_id ) ) { |
|
| 2077 | + if (empty($transaction_id)) { |
|
| 2078 | 2078 | $transaction_id = $invoice_id; |
| 2079 | 2079 | } |
| 2080 | 2080 | |
| 2081 | - $transaction_id = apply_filters( 'wpinv_set_payment_transaction_id', $transaction_id, $invoice_id ); |
|
| 2081 | + $transaction_id = apply_filters('wpinv_set_payment_transaction_id', $transaction_id, $invoice_id); |
|
| 2082 | 2082 | |
| 2083 | - return wpinv_update_invoice_meta( $invoice_id, '_wpinv_transaction_id', $transaction_id ); |
|
| 2083 | + return wpinv_update_invoice_meta($invoice_id, '_wpinv_transaction_id', $transaction_id); |
|
| 2084 | 2084 | } |
| 2085 | 2085 | |
| 2086 | -function wpinv_invoice_status_label( $status, $status_display = '' ) { |
|
| 2087 | - if ( empty( $status_display ) ) { |
|
| 2088 | - $status_display = wpinv_status_nicename( $status ); |
|
| 2086 | +function wpinv_invoice_status_label($status, $status_display = '') { |
|
| 2087 | + if (empty($status_display)) { |
|
| 2088 | + $status_display = wpinv_status_nicename($status); |
|
| 2089 | 2089 | } |
| 2090 | 2090 | |
| 2091 | - switch ( $status ) { |
|
| 2091 | + switch ($status) { |
|
| 2092 | 2092 | case 'publish' : |
| 2093 | 2093 | case 'wpi-renewal' : |
| 2094 | 2094 | $class = 'label-success'; |
@@ -2113,201 +2113,201 @@ discard block |
||
| 2113 | 2113 | |
| 2114 | 2114 | $label = '<span class="label label-inv-' . $status . ' ' . $class . '">' . $status_display . '</span>'; |
| 2115 | 2115 | |
| 2116 | - return apply_filters( 'wpinv_invoice_status_label', $label, $status, $status_display ); |
|
| 2116 | + return apply_filters('wpinv_invoice_status_label', $label, $status, $status_display); |
|
| 2117 | 2117 | } |
| 2118 | 2118 | |
| 2119 | -function wpinv_format_invoice_number( $number, $type = '' ) { |
|
| 2120 | - $check = apply_filters( 'wpinv_pre_format_invoice_number', null, $number, $type ); |
|
| 2121 | - if ( null !== $check ) { |
|
| 2119 | +function wpinv_format_invoice_number($number, $type = '') { |
|
| 2120 | + $check = apply_filters('wpinv_pre_format_invoice_number', null, $number, $type); |
|
| 2121 | + if (null !== $check) { |
|
| 2122 | 2122 | return $check; |
| 2123 | 2123 | } |
| 2124 | 2124 | |
| 2125 | - if ( !empty( $number ) && !is_numeric( $number ) ) { |
|
| 2125 | + if (!empty($number) && !is_numeric($number)) { |
|
| 2126 | 2126 | return $number; |
| 2127 | 2127 | } |
| 2128 | 2128 | |
| 2129 | - $padd = wpinv_get_option( 'invoice_number_padd' ); |
|
| 2130 | - $prefix = wpinv_get_option( 'invoice_number_prefix' ); |
|
| 2131 | - $postfix = wpinv_get_option( 'invoice_number_postfix' ); |
|
| 2129 | + $padd = wpinv_get_option('invoice_number_padd'); |
|
| 2130 | + $prefix = wpinv_get_option('invoice_number_prefix'); |
|
| 2131 | + $postfix = wpinv_get_option('invoice_number_postfix'); |
|
| 2132 | 2132 | |
| 2133 | - $padd = absint( $padd ); |
|
| 2134 | - $formatted_number = absint( $number ); |
|
| 2133 | + $padd = absint($padd); |
|
| 2134 | + $formatted_number = absint($number); |
|
| 2135 | 2135 | |
| 2136 | - if ( $padd > 0 ) { |
|
| 2137 | - $formatted_number = zeroise( $formatted_number, $padd ); |
|
| 2136 | + if ($padd > 0) { |
|
| 2137 | + $formatted_number = zeroise($formatted_number, $padd); |
|
| 2138 | 2138 | } |
| 2139 | 2139 | |
| 2140 | 2140 | $formatted_number = $prefix . $formatted_number . $postfix; |
| 2141 | 2141 | |
| 2142 | - return apply_filters( 'wpinv_format_invoice_number', $formatted_number, $number, $prefix, $postfix, $padd ); |
|
| 2142 | + return apply_filters('wpinv_format_invoice_number', $formatted_number, $number, $prefix, $postfix, $padd); |
|
| 2143 | 2143 | } |
| 2144 | 2144 | |
| 2145 | -function wpinv_get_next_invoice_number( $type = '' ) { |
|
| 2146 | - $check = apply_filters( 'wpinv_get_pre_next_invoice_number', null, $type ); |
|
| 2147 | - if ( null !== $check ) { |
|
| 2145 | +function wpinv_get_next_invoice_number($type = '') { |
|
| 2146 | + $check = apply_filters('wpinv_get_pre_next_invoice_number', null, $type); |
|
| 2147 | + if (null !== $check) { |
|
| 2148 | 2148 | return $check; |
| 2149 | 2149 | } |
| 2150 | 2150 | |
| 2151 | - if ( !wpinv_sequential_number_active() ) { |
|
| 2151 | + if (!wpinv_sequential_number_active()) { |
|
| 2152 | 2152 | return false; |
| 2153 | 2153 | } |
| 2154 | 2154 | |
| 2155 | - $number = $last_number = get_option( 'wpinv_last_invoice_number', 0 ); |
|
| 2156 | - $start = wpinv_get_option( 'invoice_sequence_start', 1 ); |
|
| 2157 | - if ( !absint( $start ) > 0 ) { |
|
| 2155 | + $number = $last_number = get_option('wpinv_last_invoice_number', 0); |
|
| 2156 | + $start = wpinv_get_option('invoice_sequence_start', 1); |
|
| 2157 | + if (!absint($start) > 0) { |
|
| 2158 | 2158 | $start = 1; |
| 2159 | 2159 | } |
| 2160 | 2160 | $increment_number = true; |
| 2161 | 2161 | $save_number = false; |
| 2162 | 2162 | |
| 2163 | - if ( !empty( $number ) && !is_numeric( $number ) && $number == wpinv_format_invoice_number( $number ) ) { |
|
| 2164 | - $number = wpinv_clean_invoice_number( $number ); |
|
| 2163 | + if (!empty($number) && !is_numeric($number) && $number == wpinv_format_invoice_number($number)) { |
|
| 2164 | + $number = wpinv_clean_invoice_number($number); |
|
| 2165 | 2165 | } |
| 2166 | 2166 | |
| 2167 | - if ( empty( $number ) ) { |
|
| 2168 | - if ( !( $last_number === 0 || $last_number === '0' ) ) { |
|
| 2169 | - $last_invoice = wpinv_get_invoices( array( 'limit' => 1, 'order' => 'DESC', 'orderby' => 'ID', 'return' => 'posts', 'fields' => 'ids', 'status' => array_keys( wpinv_get_invoice_statuses( true, true ) ) ) ); |
|
| 2167 | + if (empty($number)) { |
|
| 2168 | + if (!($last_number === 0 || $last_number === '0')) { |
|
| 2169 | + $last_invoice = wpinv_get_invoices(array('limit' => 1, 'order' => 'DESC', 'orderby' => 'ID', 'return' => 'posts', 'fields' => 'ids', 'status' => array_keys(wpinv_get_invoice_statuses(true, true)))); |
|
| 2170 | 2170 | |
| 2171 | - if ( !empty( $last_invoice[0] ) && $invoice_number = wpinv_get_invoice_number( $last_invoice[0] ) ) { |
|
| 2172 | - if ( is_numeric( $invoice_number ) ) { |
|
| 2171 | + if (!empty($last_invoice[0]) && $invoice_number = wpinv_get_invoice_number($last_invoice[0])) { |
|
| 2172 | + if (is_numeric($invoice_number)) { |
|
| 2173 | 2173 | $number = $invoice_number; |
| 2174 | 2174 | } else { |
| 2175 | - $number = wpinv_clean_invoice_number( $invoice_number ); |
|
| 2175 | + $number = wpinv_clean_invoice_number($invoice_number); |
|
| 2176 | 2176 | } |
| 2177 | 2177 | } |
| 2178 | 2178 | |
| 2179 | - if ( empty( $number ) ) { |
|
| 2179 | + if (empty($number)) { |
|
| 2180 | 2180 | $increment_number = false; |
| 2181 | 2181 | $number = $start; |
| 2182 | - $save_number = ( $number - 1 ); |
|
| 2182 | + $save_number = ($number - 1); |
|
| 2183 | 2183 | } else { |
| 2184 | 2184 | $save_number = $number; |
| 2185 | 2185 | } |
| 2186 | 2186 | } |
| 2187 | 2187 | } |
| 2188 | 2188 | |
| 2189 | - if ( $start > $number ) { |
|
| 2189 | + if ($start > $number) { |
|
| 2190 | 2190 | $increment_number = false; |
| 2191 | 2191 | $number = $start; |
| 2192 | - $save_number = ( $number - 1 ); |
|
| 2192 | + $save_number = ($number - 1); |
|
| 2193 | 2193 | } |
| 2194 | 2194 | |
| 2195 | - if ( $save_number !== false ) { |
|
| 2196 | - update_option( 'wpinv_last_invoice_number', $save_number ); |
|
| 2195 | + if ($save_number !== false) { |
|
| 2196 | + update_option('wpinv_last_invoice_number', $save_number); |
|
| 2197 | 2197 | } |
| 2198 | 2198 | |
| 2199 | - $increment_number = apply_filters( 'wpinv_increment_payment_number', $increment_number, $number ); |
|
| 2199 | + $increment_number = apply_filters('wpinv_increment_payment_number', $increment_number, $number); |
|
| 2200 | 2200 | |
| 2201 | - if ( $increment_number ) { |
|
| 2201 | + if ($increment_number) { |
|
| 2202 | 2202 | $number++; |
| 2203 | 2203 | } |
| 2204 | 2204 | |
| 2205 | - return apply_filters( 'wpinv_get_next_invoice_number', $number ); |
|
| 2205 | + return apply_filters('wpinv_get_next_invoice_number', $number); |
|
| 2206 | 2206 | } |
| 2207 | 2207 | |
| 2208 | -function wpinv_clean_invoice_number( $number, $type = '' ) { |
|
| 2209 | - $check = apply_filters( 'wpinv_pre_clean_invoice_number', null, $number, $type ); |
|
| 2210 | - if ( null !== $check ) { |
|
| 2208 | +function wpinv_clean_invoice_number($number, $type = '') { |
|
| 2209 | + $check = apply_filters('wpinv_pre_clean_invoice_number', null, $number, $type); |
|
| 2210 | + if (null !== $check) { |
|
| 2211 | 2211 | return $check; |
| 2212 | 2212 | } |
| 2213 | 2213 | |
| 2214 | - $prefix = wpinv_get_option( 'invoice_number_prefix' ); |
|
| 2215 | - $postfix = wpinv_get_option( 'invoice_number_postfix' ); |
|
| 2214 | + $prefix = wpinv_get_option('invoice_number_prefix'); |
|
| 2215 | + $postfix = wpinv_get_option('invoice_number_postfix'); |
|
| 2216 | 2216 | |
| 2217 | - $number = preg_replace( '/' . $prefix . '/', '', $number, 1 ); |
|
| 2217 | + $number = preg_replace('/' . $prefix . '/', '', $number, 1); |
|
| 2218 | 2218 | |
| 2219 | - $length = strlen( $number ); |
|
| 2220 | - $postfix_pos = strrpos( $number, $postfix ); |
|
| 2219 | + $length = strlen($number); |
|
| 2220 | + $postfix_pos = strrpos($number, $postfix); |
|
| 2221 | 2221 | |
| 2222 | - if ( false !== $postfix_pos ) { |
|
| 2223 | - $number = substr_replace( $number, '', $postfix_pos, $length ); |
|
| 2222 | + if (false !== $postfix_pos) { |
|
| 2223 | + $number = substr_replace($number, '', $postfix_pos, $length); |
|
| 2224 | 2224 | } |
| 2225 | 2225 | |
| 2226 | - $number = intval( $number ); |
|
| 2226 | + $number = intval($number); |
|
| 2227 | 2227 | |
| 2228 | - return apply_filters( 'wpinv_clean_invoice_number', $number, $prefix, $postfix ); |
|
| 2228 | + return apply_filters('wpinv_clean_invoice_number', $number, $prefix, $postfix); |
|
| 2229 | 2229 | } |
| 2230 | 2230 | |
| 2231 | -function wpinv_save_number_post_saved( $post_ID, $post, $update ) { |
|
| 2231 | +function wpinv_save_number_post_saved($post_ID, $post, $update) { |
|
| 2232 | 2232 | global $wpdb; |
| 2233 | 2233 | |
| 2234 | - if ( !$update && !get_post_meta( $post_ID, '_wpinv_number', true ) ) { |
|
| 2235 | - wpinv_update_invoice_number( $post_ID, $post->post_status != 'auto-draft', $post->post_type ); |
|
| 2234 | + if (!$update && !get_post_meta($post_ID, '_wpinv_number', true)) { |
|
| 2235 | + wpinv_update_invoice_number($post_ID, $post->post_status != 'auto-draft', $post->post_type); |
|
| 2236 | 2236 | } |
| 2237 | 2237 | |
| 2238 | - if ( !$update ) { |
|
| 2239 | - $wpdb->update( $wpdb->posts, array( 'post_name' => wpinv_generate_post_name( $post_ID ) ), array( 'ID' => $post_ID ) ); |
|
| 2240 | - clean_post_cache( $post_ID ); |
|
| 2238 | + if (!$update) { |
|
| 2239 | + $wpdb->update($wpdb->posts, array('post_name' => wpinv_generate_post_name($post_ID)), array('ID' => $post_ID)); |
|
| 2240 | + clean_post_cache($post_ID); |
|
| 2241 | 2241 | } |
| 2242 | 2242 | } |
| 2243 | -add_action( 'save_post_wpi_invoice', 'wpinv_save_number_post_saved', 1, 3 ); |
|
| 2243 | +add_action('save_post_wpi_invoice', 'wpinv_save_number_post_saved', 1, 3); |
|
| 2244 | 2244 | |
| 2245 | -function wpinv_save_number_post_updated( $post_ID, $post_after, $post_before ) { |
|
| 2246 | - if ( !empty( $post_after->post_type ) && $post_after->post_type == 'wpi_invoice' && $post_before->post_status == 'auto-draft' && $post_after->post_status != $post_before->post_status ) { |
|
| 2247 | - wpinv_update_invoice_number( $post_ID, true, $post_after->post_type ); |
|
| 2245 | +function wpinv_save_number_post_updated($post_ID, $post_after, $post_before) { |
|
| 2246 | + if (!empty($post_after->post_type) && $post_after->post_type == 'wpi_invoice' && $post_before->post_status == 'auto-draft' && $post_after->post_status != $post_before->post_status) { |
|
| 2247 | + wpinv_update_invoice_number($post_ID, true, $post_after->post_type); |
|
| 2248 | 2248 | } |
| 2249 | 2249 | } |
| 2250 | -add_action( 'post_updated', 'wpinv_save_number_post_updated', 1, 3 ); |
|
| 2250 | +add_action('post_updated', 'wpinv_save_number_post_updated', 1, 3); |
|
| 2251 | 2251 | |
| 2252 | -function wpinv_update_invoice_number( $post_ID, $save_sequential = false, $type = '' ) { |
|
| 2252 | +function wpinv_update_invoice_number($post_ID, $save_sequential = false, $type = '') { |
|
| 2253 | 2253 | global $wpdb; |
| 2254 | 2254 | |
| 2255 | - $check = apply_filters( 'wpinv_pre_update_invoice_number', null, $post_ID, $save_sequential, $type ); |
|
| 2256 | - if ( null !== $check ) { |
|
| 2255 | + $check = apply_filters('wpinv_pre_update_invoice_number', null, $post_ID, $save_sequential, $type); |
|
| 2256 | + if (null !== $check) { |
|
| 2257 | 2257 | return $check; |
| 2258 | 2258 | } |
| 2259 | 2259 | |
| 2260 | - if ( wpinv_sequential_number_active() ) { |
|
| 2260 | + if (wpinv_sequential_number_active()) { |
|
| 2261 | 2261 | $number = wpinv_get_next_invoice_number(); |
| 2262 | 2262 | |
| 2263 | - if ( $save_sequential ) { |
|
| 2264 | - update_option( 'wpinv_last_invoice_number', $number ); |
|
| 2263 | + if ($save_sequential) { |
|
| 2264 | + update_option('wpinv_last_invoice_number', $number); |
|
| 2265 | 2265 | } |
| 2266 | 2266 | } else { |
| 2267 | 2267 | $number = $post_ID; |
| 2268 | 2268 | } |
| 2269 | 2269 | |
| 2270 | - $number = wpinv_format_invoice_number( $number ); |
|
| 2270 | + $number = wpinv_format_invoice_number($number); |
|
| 2271 | 2271 | |
| 2272 | - update_post_meta( $post_ID, '_wpinv_number', $number ); |
|
| 2272 | + update_post_meta($post_ID, '_wpinv_number', $number); |
|
| 2273 | 2273 | |
| 2274 | - $wpdb->update( $wpdb->posts, array( 'post_title' => $number ), array( 'ID' => $post_ID ) ); |
|
| 2274 | + $wpdb->update($wpdb->posts, array('post_title' => $number), array('ID' => $post_ID)); |
|
| 2275 | 2275 | |
| 2276 | - clean_post_cache( $post_ID ); |
|
| 2276 | + clean_post_cache($post_ID); |
|
| 2277 | 2277 | |
| 2278 | 2278 | return $number; |
| 2279 | 2279 | } |
| 2280 | 2280 | |
| 2281 | -function wpinv_post_name_prefix( $post_type = 'wpi_invoice' ) { |
|
| 2282 | - return apply_filters( 'wpinv_post_name_prefix', 'inv-', $post_type ); |
|
| 2281 | +function wpinv_post_name_prefix($post_type = 'wpi_invoice') { |
|
| 2282 | + return apply_filters('wpinv_post_name_prefix', 'inv-', $post_type); |
|
| 2283 | 2283 | } |
| 2284 | 2284 | |
| 2285 | -function wpinv_generate_post_name( $post_ID ) { |
|
| 2286 | - $prefix = wpinv_post_name_prefix( get_post_type( $post_ID ) ); |
|
| 2287 | - $post_name = sanitize_title( $prefix . $post_ID ); |
|
| 2285 | +function wpinv_generate_post_name($post_ID) { |
|
| 2286 | + $prefix = wpinv_post_name_prefix(get_post_type($post_ID)); |
|
| 2287 | + $post_name = sanitize_title($prefix . $post_ID); |
|
| 2288 | 2288 | |
| 2289 | - return apply_filters( 'wpinv_generate_post_name', $post_name, $post_ID, $prefix ); |
|
| 2289 | + return apply_filters('wpinv_generate_post_name', $post_name, $post_ID, $prefix); |
|
| 2290 | 2290 | } |
| 2291 | 2291 | |
| 2292 | -function wpinv_is_invoice_viewed( $invoice_id ) { |
|
| 2293 | - if ( empty( $invoice_id ) ) { |
|
| 2292 | +function wpinv_is_invoice_viewed($invoice_id) { |
|
| 2293 | + if (empty($invoice_id)) { |
|
| 2294 | 2294 | return false; |
| 2295 | 2295 | } |
| 2296 | 2296 | |
| 2297 | - $viewed_meta = get_post_meta( $invoice_id, '_wpinv_is_viewed', true ); |
|
| 2297 | + $viewed_meta = get_post_meta($invoice_id, '_wpinv_is_viewed', true); |
|
| 2298 | 2298 | |
| 2299 | - return apply_filters( 'wpinv_is_invoice_viewed', 1 === (int)$viewed_meta, $invoice_id ); |
|
| 2299 | + return apply_filters('wpinv_is_invoice_viewed', 1 === (int) $viewed_meta, $invoice_id); |
|
| 2300 | 2300 | } |
| 2301 | 2301 | |
| 2302 | 2302 | function wpinv_mark_invoice_viewed() { |
| 2303 | 2303 | |
| 2304 | - if ( isset( $_GET['invoice_key'] ) || is_singular( 'wpi_invoice' ) || is_singular( 'wpi_quote' ) ) { |
|
| 2305 | - $invoice_key = isset( $_GET['invoice_key'] ) ? urldecode($_GET['invoice_key']) : ''; |
|
| 2304 | + if (isset($_GET['invoice_key']) || is_singular('wpi_invoice') || is_singular('wpi_quote')) { |
|
| 2305 | + $invoice_key = isset($_GET['invoice_key']) ? urldecode($_GET['invoice_key']) : ''; |
|
| 2306 | 2306 | global $post; |
| 2307 | 2307 | |
| 2308 | - if(!empty($invoice_key)){ |
|
| 2308 | + if (!empty($invoice_key)) { |
|
| 2309 | 2309 | $invoice_id = wpinv_get_invoice_id_by_key($invoice_key); |
| 2310 | - } else if(!empty( $post ) && ($post->post_type == 'wpi_invoice' || $post->post_type == 'wpi_quote')) { |
|
| 2310 | + } else if (!empty($post) && ($post->post_type == 'wpi_invoice' || $post->post_type == 'wpi_quote')) { |
|
| 2311 | 2311 | $invoice_id = $post->ID; |
| 2312 | 2312 | } else { |
| 2313 | 2313 | return; |
@@ -2315,63 +2315,63 @@ discard block |
||
| 2315 | 2315 | |
| 2316 | 2316 | $invoice = new WPInv_Invoice($invoice_id); |
| 2317 | 2317 | |
| 2318 | - if(!$invoice_id){ |
|
| 2318 | + if (!$invoice_id) { |
|
| 2319 | 2319 | return; |
| 2320 | 2320 | } |
| 2321 | 2321 | |
| 2322 | - if ( is_user_logged_in() ) { |
|
| 2323 | - if ( (int)$invoice->get_user_id() === get_current_user_id() ) { |
|
| 2324 | - update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2325 | - } else if ( !wpinv_require_login_to_checkout() && isset( $_GET['invoice_key'] ) && $_GET['invoice_key'] === $invoice->get_key() ) { |
|
| 2326 | - update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2322 | + if (is_user_logged_in()) { |
|
| 2323 | + if ((int) $invoice->get_user_id() === get_current_user_id()) { |
|
| 2324 | + update_post_meta($invoice_id, '_wpinv_is_viewed', 1); |
|
| 2325 | + } else if (!wpinv_require_login_to_checkout() && isset($_GET['invoice_key']) && $_GET['invoice_key'] === $invoice->get_key()) { |
|
| 2326 | + update_post_meta($invoice_id, '_wpinv_is_viewed', 1); |
|
| 2327 | 2327 | } |
| 2328 | 2328 | } else { |
| 2329 | - if ( !wpinv_require_login_to_checkout() && isset( $_GET['invoice_key'] ) && $_GET['invoice_key'] === $invoice->get_key() ) { |
|
| 2330 | - update_post_meta($invoice_id,'_wpinv_is_viewed', 1); |
|
| 2329 | + if (!wpinv_require_login_to_checkout() && isset($_GET['invoice_key']) && $_GET['invoice_key'] === $invoice->get_key()) { |
|
| 2330 | + update_post_meta($invoice_id, '_wpinv_is_viewed', 1); |
|
| 2331 | 2331 | } |
| 2332 | 2332 | } |
| 2333 | 2333 | } |
| 2334 | 2334 | |
| 2335 | 2335 | } |
| 2336 | -add_action( 'template_redirect', 'wpinv_mark_invoice_viewed' ); |
|
| 2336 | +add_action('template_redirect', 'wpinv_mark_invoice_viewed'); |
|
| 2337 | 2337 | |
| 2338 | 2338 | /** |
| 2339 | 2339 | * @return WPInv_Subscription |
| 2340 | 2340 | */ |
| 2341 | -function wpinv_get_subscription( $invoice, $by_parent = false ) { |
|
| 2342 | - if ( empty( $invoice ) ) { |
|
| 2341 | +function wpinv_get_subscription($invoice, $by_parent = false) { |
|
| 2342 | + if (empty($invoice)) { |
|
| 2343 | 2343 | return false; |
| 2344 | 2344 | } |
| 2345 | 2345 | |
| 2346 | - if ( ! is_object( $invoice ) && is_scalar( $invoice ) ) { |
|
| 2347 | - $invoice = wpinv_get_invoice( $invoice ); |
|
| 2346 | + if (!is_object($invoice) && is_scalar($invoice)) { |
|
| 2347 | + $invoice = wpinv_get_invoice($invoice); |
|
| 2348 | 2348 | } |
| 2349 | 2349 | |
| 2350 | - if ( !( is_object( $invoice ) && ! empty( $invoice->ID ) && $invoice->is_recurring() ) ) { |
|
| 2350 | + if (!(is_object($invoice) && !empty($invoice->ID) && $invoice->is_recurring())) { |
|
| 2351 | 2351 | return false; |
| 2352 | 2352 | } |
| 2353 | 2353 | |
| 2354 | - $invoice_id = ! $by_parent && ! empty( $invoice->parent_invoice ) ? $invoice->parent_invoice : $invoice->ID; |
|
| 2354 | + $invoice_id = !$by_parent && !empty($invoice->parent_invoice) ? $invoice->parent_invoice : $invoice->ID; |
|
| 2355 | 2355 | |
| 2356 | 2356 | $subs_db = new WPInv_Subscriptions_DB; |
| 2357 | - $subs = $subs_db->get_subscriptions( array( 'parent_payment_id' => $invoice_id, 'number' => 1 ) ); |
|
| 2357 | + $subs = $subs_db->get_subscriptions(array('parent_payment_id' => $invoice_id, 'number' => 1)); |
|
| 2358 | 2358 | |
| 2359 | - if ( ! empty( $subs ) ) { |
|
| 2360 | - return reset( $subs ); |
|
| 2359 | + if (!empty($subs)) { |
|
| 2360 | + return reset($subs); |
|
| 2361 | 2361 | } |
| 2362 | 2362 | |
| 2363 | 2363 | return false; |
| 2364 | 2364 | } |
| 2365 | 2365 | |
| 2366 | -function wpinv_filter_posts_clauses( $clauses, $wp_query ) { |
|
| 2366 | +function wpinv_filter_posts_clauses($clauses, $wp_query) { |
|
| 2367 | 2367 | global $wpdb; |
| 2368 | 2368 | |
| 2369 | - if ( ! empty( $wp_query->query_vars['orderby'] ) && $wp_query->query_vars['orderby'] == 'invoice_date' ) { |
|
| 2370 | - if ( !empty( $clauses['join'] ) ) { |
|
| 2369 | + if (!empty($wp_query->query_vars['orderby']) && $wp_query->query_vars['orderby'] == 'invoice_date') { |
|
| 2370 | + if (!empty($clauses['join'])) { |
|
| 2371 | 2371 | $clauses['join'] .= " "; |
| 2372 | 2372 | } |
| 2373 | 2373 | |
| 2374 | - if ( !empty( $clauses['fields'] ) ) { |
|
| 2374 | + if (!empty($clauses['fields'])) { |
|
| 2375 | 2375 | $clauses['fields'] .= ", "; |
| 2376 | 2376 | } |
| 2377 | 2377 | |
@@ -2382,4 +2382,4 @@ discard block |
||
| 2382 | 2382 | |
| 2383 | 2383 | return $clauses; |
| 2384 | 2384 | } |
| 2385 | -add_filter( 'posts_clauses', 'wpinv_filter_posts_clauses', 10, 2 ); |
|
| 2386 | 2385 | \ No newline at end of file |
| 2386 | +add_filter('posts_clauses', 'wpinv_filter_posts_clauses', 10, 2); |
|
| 2387 | 2387 | \ No newline at end of file |
@@ -1,13 +1,13 @@ discard block |
||
| 1 | 1 | <?php |
| 2 | 2 | // Exit if accessed directly |
| 3 | -if ( ! defined( 'ABSPATH' ) ) exit; |
|
| 3 | +if (!defined('ABSPATH')) exit; |
|
| 4 | 4 | |
| 5 | -add_action( 'wpinv_paypal_cc_form', '__return_false' ); |
|
| 6 | -add_filter( 'wpinv_paypal_support_subscription', '__return_true' ); |
|
| 5 | +add_action('wpinv_paypal_cc_form', '__return_false'); |
|
| 6 | +add_filter('wpinv_paypal_support_subscription', '__return_true'); |
|
| 7 | 7 | |
| 8 | -function wpinv_process_paypal_payment( $purchase_data ) { |
|
| 9 | - if( ! wp_verify_nonce( $purchase_data['gateway_nonce'], 'wpi-gateway' ) ) { |
|
| 10 | - wp_die( __( 'Nonce verification has failed', 'invoicing' ), __( 'Error', 'invoicing' ), array( 'response' => 403 ) ); |
|
| 8 | +function wpinv_process_paypal_payment($purchase_data) { |
|
| 9 | + if (!wp_verify_nonce($purchase_data['gateway_nonce'], 'wpi-gateway')) { |
|
| 10 | + wp_die(__('Nonce verification has failed', 'invoicing'), __('Error', 'invoicing'), array('response' => 403)); |
|
| 11 | 11 | } |
| 12 | 12 | |
| 13 | 13 | // Collect payment data |
@@ -25,24 +25,24 @@ discard block |
||
| 25 | 25 | ); |
| 26 | 26 | |
| 27 | 27 | // Record the pending payment |
| 28 | - $invoice = wpinv_get_invoice( $purchase_data['invoice_id'] ); |
|
| 28 | + $invoice = wpinv_get_invoice($purchase_data['invoice_id']); |
|
| 29 | 29 | |
| 30 | 30 | // Check payment |
| 31 | - if ( ! $invoice ) { |
|
| 31 | + if (!$invoice) { |
|
| 32 | 32 | // Record the error |
| 33 | - wpinv_record_gateway_error( __( 'Payment Error', 'invoicing' ), sprintf( __( 'Payment creation failed before sending buyer to PayPal. Payment data: %s', 'invoicing' ), json_encode( $payment_data ) ), $invoice ); |
|
| 33 | + wpinv_record_gateway_error(__('Payment Error', 'invoicing'), sprintf(__('Payment creation failed before sending buyer to PayPal. Payment data: %s', 'invoicing'), json_encode($payment_data)), $invoice); |
|
| 34 | 34 | // Problems? send back |
| 35 | - wpinv_send_back_to_checkout( '?payment-mode=' . $purchase_data['post_data']['wpi-gateway'] ); |
|
| 35 | + wpinv_send_back_to_checkout('?payment-mode=' . $purchase_data['post_data']['wpi-gateway']); |
|
| 36 | 36 | } else { |
| 37 | 37 | // Only send to PayPal if the pending payment is created successfully |
| 38 | - $listener_url = wpinv_get_ipn_url( 'paypal' ); |
|
| 38 | + $listener_url = wpinv_get_ipn_url('paypal'); |
|
| 39 | 39 | |
| 40 | 40 | // Get the success url |
| 41 | - $return_url = add_query_arg( array( |
|
| 41 | + $return_url = add_query_arg(array( |
|
| 42 | 42 | 'payment-confirm' => 'paypal', |
| 43 | 43 | 'invoice-id' => $invoice->ID, |
| 44 | 44 | 'utm_nooverride' => 1 |
| 45 | - ), get_permalink( wpinv_get_option( 'success_page', false ) ) ); |
|
| 45 | + ), get_permalink(wpinv_get_option('success_page', false))); |
|
| 46 | 46 | |
| 47 | 47 | // Get the PayPal redirect uri |
| 48 | 48 | $paypal_redirect = wpinv_get_paypal_redirect(); |
@@ -51,7 +51,7 @@ discard block |
||
| 51 | 51 | $paypal_args = array( |
| 52 | 52 | 'cmd' => '_cart', |
| 53 | 53 | 'upload' => '1', |
| 54 | - 'business' => wpinv_get_option( 'paypal_email', false ), |
|
| 54 | + 'business' => wpinv_get_option('paypal_email', false), |
|
| 55 | 55 | 'email' => $invoice->get_email(), |
| 56 | 56 | 'first_name' => $invoice->get_first_name(), |
| 57 | 57 | 'last_name' => $invoice->get_last_name(), |
@@ -60,88 +60,88 @@ discard block |
||
| 60 | 60 | 'shipping' => '0', |
| 61 | 61 | 'no_note' => '1', |
| 62 | 62 | 'currency_code' => $invoice->get_currency(), |
| 63 | - 'charset' => get_bloginfo( 'charset' ), |
|
| 63 | + 'charset' => get_bloginfo('charset'), |
|
| 64 | 64 | 'custom' => $invoice->ID, |
| 65 | 65 | 'rm' => is_ssl() ? 2 : 1, |
| 66 | - 'return' => esc_url_raw( $return_url ), |
|
| 66 | + 'return' => esc_url_raw($return_url), |
|
| 67 | 67 | 'cancel_return' => $invoice->get_checkout_payment_url(), |
| 68 | 68 | 'notify_url' => $listener_url, |
| 69 | - 'cbt' => get_bloginfo( 'name' ), |
|
| 69 | + 'cbt' => get_bloginfo('name'), |
|
| 70 | 70 | 'bn' => 'WPInvoicing_SP', |
| 71 | 71 | ); |
| 72 | 72 | |
| 73 | 73 | // Add cart items |
| 74 | 74 | $i = 1; |
| 75 | - if( is_array( $purchase_data['cart_details'] ) && ! empty( $purchase_data['cart_details'] ) ) { |
|
| 76 | - foreach ( $purchase_data['cart_details'] as $item ) { |
|
| 75 | + if (is_array($purchase_data['cart_details']) && !empty($purchase_data['cart_details'])) { |
|
| 76 | + foreach ($purchase_data['cart_details'] as $item) { |
|
| 77 | 77 | $item['quantity'] = $item['quantity'] > 0 ? $item['quantity'] : 1; |
| 78 | - $item_amount = wpinv_sanitize_amount( $item['subtotal'] / $item['quantity'], 2 ); |
|
| 78 | + $item_amount = wpinv_sanitize_amount($item['subtotal'] / $item['quantity'], 2); |
|
| 79 | 79 | |
| 80 | - if ( $item_amount <= 0 ) { |
|
| 80 | + if ($item_amount <= 0) { |
|
| 81 | 81 | $item_amount = 0; |
| 82 | 82 | } |
| 83 | 83 | |
| 84 | - $paypal_args['item_number_' . $i ] = $item['id']; |
|
| 85 | - $paypal_args['item_name_' . $i ] = stripslashes_deep( html_entity_decode( wpinv_get_cart_item_name( $item ), ENT_COMPAT, 'UTF-8' ) ); |
|
| 86 | - $paypal_args['quantity_' . $i ] = $item['quantity']; |
|
| 87 | - $paypal_args['amount_' . $i ] = $item_amount; |
|
| 88 | - $paypal_args['discount_amount_' . $i ] = wpinv_sanitize_amount( $item['discount'], 2 ); |
|
| 84 | + $paypal_args['item_number_' . $i] = $item['id']; |
|
| 85 | + $paypal_args['item_name_' . $i] = stripslashes_deep(html_entity_decode(wpinv_get_cart_item_name($item), ENT_COMPAT, 'UTF-8')); |
|
| 86 | + $paypal_args['quantity_' . $i] = $item['quantity']; |
|
| 87 | + $paypal_args['amount_' . $i] = $item_amount; |
|
| 88 | + $paypal_args['discount_amount_' . $i] = wpinv_sanitize_amount($item['discount'], 2); |
|
| 89 | 89 | |
| 90 | 90 | $i++; |
| 91 | 91 | } |
| 92 | 92 | } |
| 93 | 93 | |
| 94 | 94 | // Add taxes to the cart |
| 95 | - if ( wpinv_use_taxes() && $invoice->is_taxable() ) { |
|
| 96 | - $paypal_args['tax_cart'] = wpinv_sanitize_amount( (float) $invoice->get_tax(), 2 ); |
|
| 95 | + if (wpinv_use_taxes() && $invoice->is_taxable()) { |
|
| 96 | + $paypal_args['tax_cart'] = wpinv_sanitize_amount((float) $invoice->get_tax(), 2); |
|
| 97 | 97 | } |
| 98 | 98 | |
| 99 | - $paypal_args = apply_filters( 'wpinv_paypal_args', $paypal_args, $purchase_data, $invoice ); |
|
| 99 | + $paypal_args = apply_filters('wpinv_paypal_args', $paypal_args, $purchase_data, $invoice); |
|
| 100 | 100 | |
| 101 | 101 | // Build query |
| 102 | - $paypal_redirect .= http_build_query( $paypal_args ); |
|
| 102 | + $paypal_redirect .= http_build_query($paypal_args); |
|
| 103 | 103 | |
| 104 | 104 | // Fix for some sites that encode the entities |
| 105 | - $paypal_redirect = str_replace( '&', '&', $paypal_redirect ); |
|
| 105 | + $paypal_redirect = str_replace('&', '&', $paypal_redirect); |
|
| 106 | 106 | |
| 107 | 107 | // Get rid of cart contents |
| 108 | 108 | wpinv_empty_cart(); |
| 109 | 109 | |
| 110 | 110 | // Redirect to PayPal |
| 111 | - wp_redirect( $paypal_redirect ); |
|
| 111 | + wp_redirect($paypal_redirect); |
|
| 112 | 112 | exit; |
| 113 | 113 | } |
| 114 | 114 | } |
| 115 | -add_action( 'wpinv_gateway_paypal', 'wpinv_process_paypal_payment' ); |
|
| 115 | +add_action('wpinv_gateway_paypal', 'wpinv_process_paypal_payment'); |
|
| 116 | 116 | |
| 117 | -function wpinv_get_paypal_recurring_args( $paypal_args, $purchase_data, $invoice ) { |
|
| 118 | - if ( $invoice->is_recurring() && $subscription = wpinv_get_subscription( $invoice->ID ) ) { |
|
| 117 | +function wpinv_get_paypal_recurring_args($paypal_args, $purchase_data, $invoice) { |
|
| 118 | + if ($invoice->is_recurring() && $subscription = wpinv_get_subscription($invoice->ID)) { |
|
| 119 | 119 | |
| 120 | - $period = strtoupper( substr( $subscription->period, 0, 1) ); |
|
| 120 | + $period = strtoupper(substr($subscription->period, 0, 1)); |
|
| 121 | 121 | $interval = $subscription->frequency; |
| 122 | 122 | $bill_times = (int) $subscription->bill_times; |
| 123 | 123 | |
| 124 | - $initial_amount = wpinv_sanitize_amount( $invoice->get_total(), 2 ); |
|
| 125 | - $recurring_amount = wpinv_sanitize_amount( $invoice->get_recurring_details( 'total' ), 2 ); |
|
| 124 | + $initial_amount = wpinv_sanitize_amount($invoice->get_total(), 2); |
|
| 125 | + $recurring_amount = wpinv_sanitize_amount($invoice->get_recurring_details('total'), 2); |
|
| 126 | 126 | |
| 127 | 127 | $paypal_args['cmd'] = '_xclick-subscriptions'; |
| 128 | 128 | $paypal_args['sra'] = '1'; |
| 129 | 129 | $paypal_args['src'] = '1'; |
| 130 | 130 | |
| 131 | 131 | // Set item description |
| 132 | - $item_name = wpinv_get_cart_item_name( array( 'id' => $subscription->product_id ) ); |
|
| 133 | - $paypal_args['item_name'] = stripslashes_deep( html_entity_decode( $item_name, ENT_COMPAT, 'UTF-8' ) ); |
|
| 132 | + $item_name = wpinv_get_cart_item_name(array('id' => $subscription->product_id)); |
|
| 133 | + $paypal_args['item_name'] = stripslashes_deep(html_entity_decode($item_name, ENT_COMPAT, 'UTF-8')); |
|
| 134 | 134 | $paypal_args['item_number'] = $subscription->product_id; |
| 135 | - $item = new WPInv_Item( $subscription->period ); |
|
| 135 | + $item = new WPInv_Item($subscription->period); |
|
| 136 | 136 | |
| 137 | - if ( $invoice->is_free_trial() && $item->has_free_trial() ) { |
|
| 137 | + if ($invoice->is_free_trial() && $item->has_free_trial()) { |
|
| 138 | 138 | $paypal_args['a1'] = $initial_amount; |
| 139 | 139 | $paypal_args['p1'] = $item->get_trial_interval(); |
| 140 | 140 | $paypal_args['t1'] = $item->get_trial_period(); |
| 141 | 141 | |
| 142 | 142 | // Set the recurring amount |
| 143 | 143 | $paypal_args['a3'] = $recurring_amount; |
| 144 | - } else if ( $initial_amount != $recurring_amount && $bill_times != 1 ) { |
|
| 144 | + } else if ($initial_amount != $recurring_amount && $bill_times != 1) { |
|
| 145 | 145 | $paypal_args['a1'] = $initial_amount; |
| 146 | 146 | $paypal_args['p1'] = $interval; |
| 147 | 147 | $paypal_args['t1'] = $period; |
@@ -149,63 +149,63 @@ discard block |
||
| 149 | 149 | // Set the recurring amount |
| 150 | 150 | $paypal_args['a3'] = $recurring_amount; |
| 151 | 151 | |
| 152 | - if ( $bill_times > 1 ) { |
|
| 152 | + if ($bill_times > 1) { |
|
| 153 | 153 | $bill_times--; |
| 154 | 154 | } |
| 155 | 155 | } else { |
| 156 | - $paypal_args['a3'] = $initial_amount; |
|
| 156 | + $paypal_args['a3'] = $initial_amount; |
|
| 157 | 157 | } |
| 158 | 158 | |
| 159 | 159 | $paypal_args['p3'] = $interval; |
| 160 | 160 | $paypal_args['t3'] = $period; |
| 161 | 161 | |
| 162 | - if ( $bill_times > 1 ) { |
|
| 162 | + if ($bill_times > 1) { |
|
| 163 | 163 | // Make sure it's not over the max of 52 |
| 164 | - $paypal_args['srt'] = ( $bill_times <= 52 ? absint( $bill_times ) : 52 ); |
|
| 164 | + $paypal_args['srt'] = ($bill_times <= 52 ? absint($bill_times) : 52); |
|
| 165 | 165 | } |
| 166 | 166 | |
| 167 | 167 | // Remove cart items |
| 168 | 168 | $i = 1; |
| 169 | - if( is_array( $purchase_data['cart_details'] ) && ! empty( $purchase_data['cart_details'] ) ) { |
|
| 170 | - foreach ( $purchase_data['cart_details'] as $item ) { |
|
| 171 | - if ( isset( $paypal_args['item_number_' . $i] ) ) { |
|
| 172 | - unset( $paypal_args['item_number_' . $i] ); |
|
| 169 | + if (is_array($purchase_data['cart_details']) && !empty($purchase_data['cart_details'])) { |
|
| 170 | + foreach ($purchase_data['cart_details'] as $item) { |
|
| 171 | + if (isset($paypal_args['item_number_' . $i])) { |
|
| 172 | + unset($paypal_args['item_number_' . $i]); |
|
| 173 | 173 | } |
| 174 | - if ( isset( $paypal_args['item_name_' . $i] ) ) { |
|
| 175 | - unset( $paypal_args['item_name_' . $i] ); |
|
| 174 | + if (isset($paypal_args['item_name_' . $i])) { |
|
| 175 | + unset($paypal_args['item_name_' . $i]); |
|
| 176 | 176 | } |
| 177 | - if ( isset( $paypal_args['quantity_' . $i] ) ) { |
|
| 178 | - unset( $paypal_args['quantity_' . $i] ); |
|
| 177 | + if (isset($paypal_args['quantity_' . $i])) { |
|
| 178 | + unset($paypal_args['quantity_' . $i]); |
|
| 179 | 179 | } |
| 180 | - if ( isset( $paypal_args['amount_' . $i] ) ) { |
|
| 181 | - unset( $paypal_args['amount_' . $i] ); |
|
| 180 | + if (isset($paypal_args['amount_' . $i])) { |
|
| 181 | + unset($paypal_args['amount_' . $i]); |
|
| 182 | 182 | } |
| 183 | - if ( isset( $paypal_args['discount_amount_' . $i] ) ) { |
|
| 184 | - unset( $paypal_args['discount_amount_' . $i] ); |
|
| 183 | + if (isset($paypal_args['discount_amount_' . $i])) { |
|
| 184 | + unset($paypal_args['discount_amount_' . $i]); |
|
| 185 | 185 | } |
| 186 | 186 | |
| 187 | 187 | $i++; |
| 188 | 188 | } |
| 189 | 189 | } |
| 190 | 190 | |
| 191 | - if ( isset( $paypal_args['tax_cart'] ) ) { |
|
| 192 | - unset( $paypal_args['tax_cart'] ); |
|
| 191 | + if (isset($paypal_args['tax_cart'])) { |
|
| 192 | + unset($paypal_args['tax_cart']); |
|
| 193 | 193 | } |
| 194 | 194 | |
| 195 | - if ( isset( $paypal_args['upload'] ) ) { |
|
| 196 | - unset( $paypal_args['upload'] ); |
|
| 195 | + if (isset($paypal_args['upload'])) { |
|
| 196 | + unset($paypal_args['upload']); |
|
| 197 | 197 | } |
| 198 | 198 | |
| 199 | - $paypal_args = apply_filters( 'wpinv_paypal_recurring_args', $paypal_args, $purchase_data, $invoice ); |
|
| 199 | + $paypal_args = apply_filters('wpinv_paypal_recurring_args', $paypal_args, $purchase_data, $invoice); |
|
| 200 | 200 | } |
| 201 | 201 | |
| 202 | 202 | return $paypal_args; |
| 203 | 203 | } |
| 204 | -add_filter( 'wpinv_paypal_args', 'wpinv_get_paypal_recurring_args', 10, 3 ); |
|
| 204 | +add_filter('wpinv_paypal_args', 'wpinv_get_paypal_recurring_args', 10, 3); |
|
| 205 | 205 | |
| 206 | 206 | function wpinv_process_paypal_ipn() { |
| 207 | 207 | // Check the request method is POST |
| 208 | - if ( isset( $_SERVER['REQUEST_METHOD'] ) && $_SERVER['REQUEST_METHOD'] != 'POST' ) { |
|
| 208 | + if (isset($_SERVER['REQUEST_METHOD']) && $_SERVER['REQUEST_METHOD'] != 'POST') { |
|
| 209 | 209 | return; |
| 210 | 210 | } |
| 211 | 211 | |
@@ -213,11 +213,11 @@ discard block |
||
| 213 | 213 | $post_data = ''; |
| 214 | 214 | |
| 215 | 215 | // Fallback just in case post_max_size is lower than needed |
| 216 | - if ( ini_get( 'allow_url_fopen' ) ) { |
|
| 217 | - $post_data = file_get_contents( 'php://input' ); |
|
| 216 | + if (ini_get('allow_url_fopen')) { |
|
| 217 | + $post_data = file_get_contents('php://input'); |
|
| 218 | 218 | } else { |
| 219 | 219 | // If allow_url_fopen is not enabled, then make sure that post_max_size is large enough |
| 220 | - ini_set( 'post_max_size', '12M' ); |
|
| 220 | + ini_set('post_max_size', '12M'); |
|
| 221 | 221 | } |
| 222 | 222 | // Start the encoded data collection with notification command |
| 223 | 223 | $encoded_data = 'cmd=_notify-validate'; |
@@ -226,43 +226,43 @@ discard block |
||
| 226 | 226 | $arg_separator = wpinv_get_php_arg_separator_output(); |
| 227 | 227 | |
| 228 | 228 | // Verify there is a post_data |
| 229 | - if ( $post_data || strlen( $post_data ) > 0 ) { |
|
| 229 | + if ($post_data || strlen($post_data) > 0) { |
|
| 230 | 230 | // Append the data |
| 231 | - $encoded_data .= $arg_separator.$post_data; |
|
| 231 | + $encoded_data .= $arg_separator . $post_data; |
|
| 232 | 232 | } else { |
| 233 | 233 | // Check if POST is empty |
| 234 | - if ( empty( $_POST ) ) { |
|
| 234 | + if (empty($_POST)) { |
|
| 235 | 235 | // Nothing to do |
| 236 | 236 | return; |
| 237 | 237 | } else { |
| 238 | 238 | // Loop through each POST |
| 239 | - foreach ( $_POST as $key => $value ) { |
|
| 239 | + foreach ($_POST as $key => $value) { |
|
| 240 | 240 | // Encode the value and append the data |
| 241 | - $encoded_data .= $arg_separator."$key=" . urlencode( $value ); |
|
| 241 | + $encoded_data .= $arg_separator . "$key=" . urlencode($value); |
|
| 242 | 242 | } |
| 243 | 243 | } |
| 244 | 244 | } |
| 245 | 245 | |
| 246 | 246 | // Convert collected post data to an array |
| 247 | - wp_parse_str( $encoded_data, $encoded_data_array ); |
|
| 247 | + wp_parse_str($encoded_data, $encoded_data_array); |
|
| 248 | 248 | |
| 249 | - foreach ( $encoded_data_array as $key => $value ) { |
|
| 250 | - if ( false !== strpos( $key, 'amp;' ) ) { |
|
| 251 | - $new_key = str_replace( '&', '&', $key ); |
|
| 252 | - $new_key = str_replace( 'amp;', '&' , $new_key ); |
|
| 249 | + foreach ($encoded_data_array as $key => $value) { |
|
| 250 | + if (false !== strpos($key, 'amp;')) { |
|
| 251 | + $new_key = str_replace('&', '&', $key); |
|
| 252 | + $new_key = str_replace('amp;', '&', $new_key); |
|
| 253 | 253 | |
| 254 | - unset( $encoded_data_array[ $key ] ); |
|
| 255 | - $encoded_data_array[ $new_key ] = $value; |
|
| 254 | + unset($encoded_data_array[$key]); |
|
| 255 | + $encoded_data_array[$new_key] = $value; |
|
| 256 | 256 | } |
| 257 | 257 | } |
| 258 | 258 | |
| 259 | 259 | // Get the PayPal redirect uri |
| 260 | - $paypal_redirect = wpinv_get_paypal_redirect( true ); |
|
| 260 | + $paypal_redirect = wpinv_get_paypal_redirect(true); |
|
| 261 | 261 | |
| 262 | - if ( !wpinv_get_option( 'disable_paypal_verification', false ) ) { |
|
| 262 | + if (!wpinv_get_option('disable_paypal_verification', false)) { |
|
| 263 | 263 | // Validate the IPN |
| 264 | 264 | |
| 265 | - $remote_post_vars = array( |
|
| 265 | + $remote_post_vars = array( |
|
| 266 | 266 | 'method' => 'POST', |
| 267 | 267 | 'timeout' => 45, |
| 268 | 268 | 'redirection' => 5, |
@@ -280,21 +280,21 @@ discard block |
||
| 280 | 280 | ); |
| 281 | 281 | |
| 282 | 282 | // Get response |
| 283 | - $api_response = wp_remote_post( wpinv_get_paypal_redirect(), $remote_post_vars ); |
|
| 283 | + $api_response = wp_remote_post(wpinv_get_paypal_redirect(), $remote_post_vars); |
|
| 284 | 284 | |
| 285 | - if ( is_wp_error( $api_response ) ) { |
|
| 286 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid IPN verification response. IPN data: %s', 'invoicing' ), json_encode( $api_response ) ) ); |
|
| 285 | + if (is_wp_error($api_response)) { |
|
| 286 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid IPN verification response. IPN data: %s', 'invoicing'), json_encode($api_response))); |
|
| 287 | 287 | return; // Something went wrong |
| 288 | 288 | } |
| 289 | 289 | |
| 290 | - if ( $api_response['body'] !== 'VERIFIED' && wpinv_get_option( 'disable_paypal_verification', false ) ) { |
|
| 291 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid IPN verification response. IPN data: %s', 'invoicing' ), json_encode( $api_response ) ) ); |
|
| 290 | + if ($api_response['body'] !== 'VERIFIED' && wpinv_get_option('disable_paypal_verification', false)) { |
|
| 291 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid IPN verification response. IPN data: %s', 'invoicing'), json_encode($api_response))); |
|
| 292 | 292 | return; // Response not okay |
| 293 | 293 | } |
| 294 | 294 | } |
| 295 | 295 | |
| 296 | 296 | // Check if $post_data_array has been populated |
| 297 | - if ( !is_array( $encoded_data_array ) && !empty( $encoded_data_array ) ) |
|
| 297 | + if (!is_array($encoded_data_array) && !empty($encoded_data_array)) |
|
| 298 | 298 | return; |
| 299 | 299 | |
| 300 | 300 | $defaults = array( |
@@ -302,265 +302,265 @@ discard block |
||
| 302 | 302 | 'payment_status' => '' |
| 303 | 303 | ); |
| 304 | 304 | |
| 305 | - $encoded_data_array = wp_parse_args( $encoded_data_array, $defaults ); |
|
| 305 | + $encoded_data_array = wp_parse_args($encoded_data_array, $defaults); |
|
| 306 | 306 | |
| 307 | - $invoice_id = isset( $encoded_data_array['custom'] ) ? absint( $encoded_data_array['custom'] ) : 0; |
|
| 307 | + $invoice_id = isset($encoded_data_array['custom']) ? absint($encoded_data_array['custom']) : 0; |
|
| 308 | 308 | |
| 309 | - wpinv_error_log( $encoded_data_array['txn_type'], 'PayPal txn_type', __FILE__, __LINE__ ); |
|
| 310 | - wpinv_error_log( $encoded_data_array, 'PayPal IPN response', __FILE__, __LINE__ ); |
|
| 309 | + wpinv_error_log($encoded_data_array['txn_type'], 'PayPal txn_type', __FILE__, __LINE__); |
|
| 310 | + wpinv_error_log($encoded_data_array, 'PayPal IPN response', __FILE__, __LINE__); |
|
| 311 | 311 | |
| 312 | - if ( has_action( 'wpinv_paypal_' . $encoded_data_array['txn_type'] ) ) { |
|
| 312 | + if (has_action('wpinv_paypal_' . $encoded_data_array['txn_type'])) { |
|
| 313 | 313 | // Allow PayPal IPN types to be processed separately |
| 314 | - do_action( 'wpinv_paypal_' . $encoded_data_array['txn_type'], $encoded_data_array, $invoice_id ); |
|
| 314 | + do_action('wpinv_paypal_' . $encoded_data_array['txn_type'], $encoded_data_array, $invoice_id); |
|
| 315 | 315 | } else { |
| 316 | 316 | // Fallback to web accept just in case the txn_type isn't present |
| 317 | - do_action( 'wpinv_paypal_web_accept', $encoded_data_array, $invoice_id ); |
|
| 317 | + do_action('wpinv_paypal_web_accept', $encoded_data_array, $invoice_id); |
|
| 318 | 318 | } |
| 319 | 319 | exit; |
| 320 | 320 | } |
| 321 | -add_action( 'wpinv_verify_paypal_ipn', 'wpinv_process_paypal_ipn' ); |
|
| 321 | +add_action('wpinv_verify_paypal_ipn', 'wpinv_process_paypal_ipn'); |
|
| 322 | 322 | |
| 323 | -function wpinv_process_paypal_web_accept_and_cart( $data, $invoice_id ) { |
|
| 324 | - if ( $data['txn_type'] != 'web_accept' && $data['txn_type'] != 'cart' && $data['payment_status'] != 'Refunded' ) { |
|
| 323 | +function wpinv_process_paypal_web_accept_and_cart($data, $invoice_id) { |
|
| 324 | + if ($data['txn_type'] != 'web_accept' && $data['txn_type'] != 'cart' && $data['payment_status'] != 'Refunded') { |
|
| 325 | 325 | return; |
| 326 | 326 | } |
| 327 | 327 | |
| 328 | - if( empty( $invoice_id ) ) { |
|
| 328 | + if (empty($invoice_id)) { |
|
| 329 | 329 | return; |
| 330 | 330 | } |
| 331 | 331 | |
| 332 | 332 | // Collect payment details |
| 333 | - $purchase_key = isset( $data['invoice'] ) ? $data['invoice'] : $data['item_number']; |
|
| 333 | + $purchase_key = isset($data['invoice']) ? $data['invoice'] : $data['item_number']; |
|
| 334 | 334 | $paypal_amount = $data['mc_gross']; |
| 335 | - $payment_status = strtolower( $data['payment_status'] ); |
|
| 336 | - $currency_code = strtolower( $data['mc_currency'] ); |
|
| 337 | - $business_email = isset( $data['business'] ) && is_email( $data['business'] ) ? trim( $data['business'] ) : trim( $data['receiver_email'] ); |
|
| 338 | - $payment_meta = wpinv_get_invoice_meta( $invoice_id ); |
|
| 335 | + $payment_status = strtolower($data['payment_status']); |
|
| 336 | + $currency_code = strtolower($data['mc_currency']); |
|
| 337 | + $business_email = isset($data['business']) && is_email($data['business']) ? trim($data['business']) : trim($data['receiver_email']); |
|
| 338 | + $payment_meta = wpinv_get_invoice_meta($invoice_id); |
|
| 339 | 339 | |
| 340 | - if ( wpinv_get_payment_gateway( $invoice_id ) != 'paypal' ) { |
|
| 340 | + if (wpinv_get_payment_gateway($invoice_id) != 'paypal') { |
|
| 341 | 341 | return; // this isn't a PayPal standard IPN |
| 342 | 342 | } |
| 343 | 343 | |
| 344 | 344 | // Verify payment recipient |
| 345 | - if ( strcasecmp( $business_email, trim( wpinv_get_option( 'paypal_email', false ) ) ) != 0 ) { |
|
| 346 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid business email in IPN response. IPN data: %s', 'invoicing' ), json_encode( $data ) ), $invoice_id ); |
|
| 347 | - wpinv_update_payment_status( $invoice_id, 'wpi-failed' ); |
|
| 348 | - wpinv_insert_payment_note( $invoice_id, __( 'Payment failed due to invalid PayPal business email.', 'invoicing' ), '', '', true ); |
|
| 345 | + if (strcasecmp($business_email, trim(wpinv_get_option('paypal_email', false))) != 0) { |
|
| 346 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid business email in IPN response. IPN data: %s', 'invoicing'), json_encode($data)), $invoice_id); |
|
| 347 | + wpinv_update_payment_status($invoice_id, 'wpi-failed'); |
|
| 348 | + wpinv_insert_payment_note($invoice_id, __('Payment failed due to invalid PayPal business email.', 'invoicing'), '', '', true); |
|
| 349 | 349 | return; |
| 350 | 350 | } |
| 351 | 351 | |
| 352 | 352 | // Verify payment currency |
| 353 | - if ( $currency_code != strtolower( $payment_meta['currency'] ) ) { |
|
| 354 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid currency in IPN response. IPN data: %s', 'invoicing' ), json_encode( $data ) ), $invoice_id ); |
|
| 355 | - wpinv_update_payment_status( $invoice_id, 'wpi-failed' ); |
|
| 356 | - wpinv_insert_payment_note( $invoice_id, __( 'Payment failed due to invalid currency in PayPal IPN.', 'invoicing' ), '', '', true ); |
|
| 353 | + if ($currency_code != strtolower($payment_meta['currency'])) { |
|
| 354 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid currency in IPN response. IPN data: %s', 'invoicing'), json_encode($data)), $invoice_id); |
|
| 355 | + wpinv_update_payment_status($invoice_id, 'wpi-failed'); |
|
| 356 | + wpinv_insert_payment_note($invoice_id, __('Payment failed due to invalid currency in PayPal IPN.', 'invoicing'), '', '', true); |
|
| 357 | 357 | return; |
| 358 | 358 | } |
| 359 | 359 | |
| 360 | - if ( !wpinv_get_payment_user_email( $invoice_id ) ) { |
|
| 360 | + if (!wpinv_get_payment_user_email($invoice_id)) { |
|
| 361 | 361 | // This runs when a Buy Now purchase was made. It bypasses checkout so no personal info is collected until PayPal |
| 362 | 362 | // No email associated with purchase, so store from PayPal |
| 363 | - wpinv_update_invoice_meta( $invoice_id, '_wpinv_email', $data['payer_email'] ); |
|
| 363 | + wpinv_update_invoice_meta($invoice_id, '_wpinv_email', $data['payer_email']); |
|
| 364 | 364 | |
| 365 | 365 | // Setup and store the customer's details |
| 366 | 366 | $user_info = array( |
| 367 | 367 | 'user_id' => '-1', |
| 368 | - 'email' => sanitize_text_field( $data['payer_email'] ), |
|
| 369 | - 'first_name' => sanitize_text_field( $data['first_name'] ), |
|
| 370 | - 'last_name' => sanitize_text_field( $data['last_name'] ), |
|
| 368 | + 'email' => sanitize_text_field($data['payer_email']), |
|
| 369 | + 'first_name' => sanitize_text_field($data['first_name']), |
|
| 370 | + 'last_name' => sanitize_text_field($data['last_name']), |
|
| 371 | 371 | 'discount' => '', |
| 372 | 372 | ); |
| 373 | - $user_info['address'] = ! empty( $data['address_street'] ) ? sanitize_text_field( $data['address_street'] ) : false; |
|
| 374 | - $user_info['city'] = ! empty( $data['address_city'] ) ? sanitize_text_field( $data['address_city'] ) : false; |
|
| 375 | - $user_info['state'] = ! empty( $data['address_state'] ) ? sanitize_text_field( $data['address_state'] ) : false; |
|
| 376 | - $user_info['country'] = ! empty( $data['address_country_code'] ) ? sanitize_text_field( $data['address_country_code'] ) : false; |
|
| 377 | - $user_info['zip'] = ! empty( $data['address_zip'] ) ? sanitize_text_field( $data['address_zip'] ) : false; |
|
| 373 | + $user_info['address'] = !empty($data['address_street']) ? sanitize_text_field($data['address_street']) : false; |
|
| 374 | + $user_info['city'] = !empty($data['address_city']) ? sanitize_text_field($data['address_city']) : false; |
|
| 375 | + $user_info['state'] = !empty($data['address_state']) ? sanitize_text_field($data['address_state']) : false; |
|
| 376 | + $user_info['country'] = !empty($data['address_country_code']) ? sanitize_text_field($data['address_country_code']) : false; |
|
| 377 | + $user_info['zip'] = !empty($data['address_zip']) ? sanitize_text_field($data['address_zip']) : false; |
|
| 378 | 378 | |
| 379 | 379 | $payment_meta['user_info'] = $user_info; |
| 380 | - wpinv_update_invoice_meta( $invoice_id, '_wpinv_payment_meta', $payment_meta ); |
|
| 380 | + wpinv_update_invoice_meta($invoice_id, '_wpinv_payment_meta', $payment_meta); |
|
| 381 | 381 | } |
| 382 | 382 | |
| 383 | - if ( $payment_status == 'refunded' || $payment_status == 'reversed' ) { |
|
| 383 | + if ($payment_status == 'refunded' || $payment_status == 'reversed') { |
|
| 384 | 384 | // Process a refund |
| 385 | - wpinv_process_paypal_refund( $data, $invoice_id ); |
|
| 385 | + wpinv_process_paypal_refund($data, $invoice_id); |
|
| 386 | 386 | } else { |
| 387 | - if ( get_post_status( $invoice_id ) == 'publish' ) { |
|
| 387 | + if (get_post_status($invoice_id) == 'publish') { |
|
| 388 | 388 | return; // Only paid payments once |
| 389 | 389 | } |
| 390 | 390 | |
| 391 | 391 | // Retrieve the total purchase amount (before PayPal) |
| 392 | - $payment_amount = wpinv_payment_total( $invoice_id ); |
|
| 392 | + $payment_amount = wpinv_payment_total($invoice_id); |
|
| 393 | 393 | |
| 394 | - if ( number_format( (float) $paypal_amount, 2 ) < number_format( (float) $payment_amount, 2 ) ) { |
|
| 394 | + if (number_format((float) $paypal_amount, 2) < number_format((float) $payment_amount, 2)) { |
|
| 395 | 395 | // The prices don't match |
| 396 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid payment amount in IPN response. IPN data: %s', 'invoicing' ), json_encode( $data ) ), $invoice_id ); |
|
| 397 | - wpinv_update_payment_status( $invoice_id, 'wpi-failed' ); |
|
| 398 | - wpinv_insert_payment_note( $invoice_id, __( 'Payment failed due to invalid amount in PayPal IPN.', 'invoicing' ), '', '', true ); |
|
| 396 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid payment amount in IPN response. IPN data: %s', 'invoicing'), json_encode($data)), $invoice_id); |
|
| 397 | + wpinv_update_payment_status($invoice_id, 'wpi-failed'); |
|
| 398 | + wpinv_insert_payment_note($invoice_id, __('Payment failed due to invalid amount in PayPal IPN.', 'invoicing'), '', '', true); |
|
| 399 | 399 | return; |
| 400 | 400 | } |
| 401 | - if ( $purchase_key != wpinv_get_payment_key( $invoice_id ) ) { |
|
| 401 | + if ($purchase_key != wpinv_get_payment_key($invoice_id)) { |
|
| 402 | 402 | // Purchase keys don't match |
| 403 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid purchase key in IPN response. IPN data: %s', 'invoicing' ), json_encode( $data ) ), $invoice_id ); |
|
| 404 | - wpinv_update_payment_status( $invoice_id, 'wpi-failed' ); |
|
| 405 | - wpinv_insert_payment_note( $invoice_id, __( 'Payment failed due to invalid purchase key in PayPal IPN.', 'invoicing' ), '', '', true ); |
|
| 403 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid purchase key in IPN response. IPN data: %s', 'invoicing'), json_encode($data)), $invoice_id); |
|
| 404 | + wpinv_update_payment_status($invoice_id, 'wpi-failed'); |
|
| 405 | + wpinv_insert_payment_note($invoice_id, __('Payment failed due to invalid purchase key in PayPal IPN.', 'invoicing'), '', '', true); |
|
| 406 | 406 | return; |
| 407 | 407 | } |
| 408 | 408 | |
| 409 | - if ( 'complete' == $payment_status || 'completed' == $payment_status || 'processed' == $payment_status || wpinv_is_test_mode( 'paypal' ) ) { |
|
| 410 | - wpinv_insert_payment_note( $invoice_id, sprintf( __( 'PayPal Transaction ID: %s', 'invoicing' ) , $data['txn_id'] ), '', '', true ); |
|
| 411 | - wpinv_set_payment_transaction_id( $invoice_id, $data['txn_id'] ); |
|
| 412 | - wpinv_update_payment_status( $invoice_id, 'publish' ); |
|
| 413 | - } else if ( 'pending' == $payment_status && isset( $data['pending_reason'] ) ) { |
|
| 409 | + if ('complete' == $payment_status || 'completed' == $payment_status || 'processed' == $payment_status || wpinv_is_test_mode('paypal')) { |
|
| 410 | + wpinv_insert_payment_note($invoice_id, sprintf(__('PayPal Transaction ID: %s', 'invoicing'), $data['txn_id']), '', '', true); |
|
| 411 | + wpinv_set_payment_transaction_id($invoice_id, $data['txn_id']); |
|
| 412 | + wpinv_update_payment_status($invoice_id, 'publish'); |
|
| 413 | + } else if ('pending' == $payment_status && isset($data['pending_reason'])) { |
|
| 414 | 414 | // Look for possible pending reasons, such as an echeck |
| 415 | 415 | $note = ''; |
| 416 | 416 | |
| 417 | - switch( strtolower( $data['pending_reason'] ) ) { |
|
| 417 | + switch (strtolower($data['pending_reason'])) { |
|
| 418 | 418 | case 'echeck' : |
| 419 | - $note = __( 'Payment made via eCheck and will clear automatically in 5-8 days', 'invoicing' ); |
|
| 419 | + $note = __('Payment made via eCheck and will clear automatically in 5-8 days', 'invoicing'); |
|
| 420 | 420 | break; |
| 421 | 421 | |
| 422 | 422 | case 'address' : |
| 423 | - $note = __( 'Payment requires a confirmed customer address and must be accepted manually through PayPal', 'invoicing' ); |
|
| 423 | + $note = __('Payment requires a confirmed customer address and must be accepted manually through PayPal', 'invoicing'); |
|
| 424 | 424 | break; |
| 425 | 425 | |
| 426 | 426 | case 'intl' : |
| 427 | - $note = __( 'Payment must be accepted manually through PayPal due to international account regulations', 'invoicing' ); |
|
| 427 | + $note = __('Payment must be accepted manually through PayPal due to international account regulations', 'invoicing'); |
|
| 428 | 428 | break; |
| 429 | 429 | |
| 430 | 430 | case 'multi-currency' : |
| 431 | - $note = __( 'Payment received in non-shop currency and must be accepted manually through PayPal', 'invoicing' ); |
|
| 431 | + $note = __('Payment received in non-shop currency and must be accepted manually through PayPal', 'invoicing'); |
|
| 432 | 432 | break; |
| 433 | 433 | |
| 434 | 434 | case 'paymentreview' : |
| 435 | 435 | case 'regulatory_review' : |
| 436 | - $note = __( 'Payment is being reviewed by PayPal staff as high-risk or in possible violation of government regulations', 'invoicing' ); |
|
| 436 | + $note = __('Payment is being reviewed by PayPal staff as high-risk or in possible violation of government regulations', 'invoicing'); |
|
| 437 | 437 | break; |
| 438 | 438 | |
| 439 | 439 | case 'unilateral' : |
| 440 | - $note = __( 'Payment was sent to non-confirmed or non-registered email address.', 'invoicing' ); |
|
| 440 | + $note = __('Payment was sent to non-confirmed or non-registered email address.', 'invoicing'); |
|
| 441 | 441 | break; |
| 442 | 442 | |
| 443 | 443 | case 'upgrade' : |
| 444 | - $note = __( 'PayPal account must be upgraded before this payment can be accepted', 'invoicing' ); |
|
| 444 | + $note = __('PayPal account must be upgraded before this payment can be accepted', 'invoicing'); |
|
| 445 | 445 | break; |
| 446 | 446 | |
| 447 | 447 | case 'verify' : |
| 448 | - $note = __( 'PayPal account is not verified. Verify account in order to accept this payment', 'invoicing' ); |
|
| 448 | + $note = __('PayPal account is not verified. Verify account in order to accept this payment', 'invoicing'); |
|
| 449 | 449 | break; |
| 450 | 450 | |
| 451 | 451 | case 'other' : |
| 452 | - $note = __( 'Payment is pending for unknown reasons. Contact PayPal support for assistance', 'invoicing' ); |
|
| 452 | + $note = __('Payment is pending for unknown reasons. Contact PayPal support for assistance', 'invoicing'); |
|
| 453 | 453 | break; |
| 454 | 454 | } |
| 455 | 455 | |
| 456 | - if ( ! empty( $note ) ) { |
|
| 457 | - wpinv_insert_payment_note( $invoice_id, $note, '', '', true ); |
|
| 456 | + if (!empty($note)) { |
|
| 457 | + wpinv_insert_payment_note($invoice_id, $note, '', '', true); |
|
| 458 | 458 | } |
| 459 | 459 | } else { |
| 460 | - wpinv_insert_payment_note( $invoice_id, wp_sprintf( __( 'PayPal IPN has been received with invalid payment status: %s', 'invoicing' ), $payment_status ), '', '', true ); |
|
| 460 | + wpinv_insert_payment_note($invoice_id, wp_sprintf(__('PayPal IPN has been received with invalid payment status: %s', 'invoicing'), $payment_status), '', '', true); |
|
| 461 | 461 | } |
| 462 | 462 | } |
| 463 | 463 | } |
| 464 | -add_action( 'wpinv_paypal_web_accept', 'wpinv_process_paypal_web_accept_and_cart', 10, 2 ); |
|
| 464 | +add_action('wpinv_paypal_web_accept', 'wpinv_process_paypal_web_accept_and_cart', 10, 2); |
|
| 465 | 465 | |
| 466 | 466 | // Process PayPal subscription sign ups |
| 467 | -add_action( 'wpinv_paypal_subscr_signup', 'wpinv_process_paypal_subscr_signup' ); |
|
| 467 | +add_action('wpinv_paypal_subscr_signup', 'wpinv_process_paypal_subscr_signup'); |
|
| 468 | 468 | |
| 469 | 469 | // Process PayPal subscription payments |
| 470 | -add_action( 'wpinv_paypal_subscr_payment', 'wpinv_process_paypal_subscr_payment' ); |
|
| 470 | +add_action('wpinv_paypal_subscr_payment', 'wpinv_process_paypal_subscr_payment'); |
|
| 471 | 471 | |
| 472 | 472 | // Process PayPal subscription cancellations |
| 473 | -add_action( 'wpinv_paypal_subscr_cancel', 'wpinv_process_paypal_subscr_cancel' ); |
|
| 473 | +add_action('wpinv_paypal_subscr_cancel', 'wpinv_process_paypal_subscr_cancel'); |
|
| 474 | 474 | |
| 475 | 475 | // Process PayPal subscription end of term notices |
| 476 | -add_action( 'wpinv_paypal_subscr_eot', 'wpinv_process_paypal_subscr_eot' ); |
|
| 476 | +add_action('wpinv_paypal_subscr_eot', 'wpinv_process_paypal_subscr_eot'); |
|
| 477 | 477 | |
| 478 | 478 | // Process PayPal payment failed |
| 479 | -add_action( 'wpinv_paypal_subscr_failed', 'wpinv_process_paypal_subscr_failed' ); |
|
| 479 | +add_action('wpinv_paypal_subscr_failed', 'wpinv_process_paypal_subscr_failed'); |
|
| 480 | 480 | |
| 481 | 481 | |
| 482 | 482 | /** |
| 483 | 483 | * Process the subscription started IPN. |
| 484 | 484 | */ |
| 485 | -function wpinv_process_paypal_subscr_signup( $ipn_data ) { |
|
| 486 | - $parent_invoice_id = absint( $ipn_data['custom'] ); |
|
| 487 | - if( empty( $parent_invoice_id ) ) { |
|
| 485 | +function wpinv_process_paypal_subscr_signup($ipn_data) { |
|
| 486 | + $parent_invoice_id = absint($ipn_data['custom']); |
|
| 487 | + if (empty($parent_invoice_id)) { |
|
| 488 | 488 | return; |
| 489 | 489 | } |
| 490 | 490 | |
| 491 | - $invoice = wpinv_get_invoice( $parent_invoice_id ); |
|
| 492 | - if ( empty( $invoice ) ) { |
|
| 491 | + $invoice = wpinv_get_invoice($parent_invoice_id); |
|
| 492 | + if (empty($invoice)) { |
|
| 493 | 493 | return; |
| 494 | 494 | } |
| 495 | 495 | |
| 496 | - if ( $invoice->is_free_trial() && !empty( $ipn_data['invoice'] ) ) { |
|
| 497 | - wpinv_insert_payment_note( $parent_invoice_id, sprintf( __( 'PayPal Invoice ID: %s', 'invoicing' ) , $ipn_data['invoice'] ), '', '', true); |
|
| 498 | - if ( !empty( $ipn_data['txn_id'] ) ) { |
|
| 499 | - wpinv_set_payment_transaction_id( $parent_invoice_id, $ipn_data['txn_id'] ); |
|
| 496 | + if ($invoice->is_free_trial() && !empty($ipn_data['invoice'])) { |
|
| 497 | + wpinv_insert_payment_note($parent_invoice_id, sprintf(__('PayPal Invoice ID: %s', 'invoicing'), $ipn_data['invoice']), '', '', true); |
|
| 498 | + if (!empty($ipn_data['txn_id'])) { |
|
| 499 | + wpinv_set_payment_transaction_id($parent_invoice_id, $ipn_data['txn_id']); |
|
| 500 | 500 | } |
| 501 | 501 | } |
| 502 | 502 | |
| 503 | - $subscription = wpinv_get_paypal_subscription( $ipn_data ); |
|
| 504 | - if ( false === $subscription ) { |
|
| 503 | + $subscription = wpinv_get_paypal_subscription($ipn_data); |
|
| 504 | + if (false === $subscription) { |
|
| 505 | 505 | return; |
| 506 | 506 | } |
| 507 | 507 | |
| 508 | - wpinv_update_payment_status( $parent_invoice_id, 'publish' ); |
|
| 508 | + wpinv_update_payment_status($parent_invoice_id, 'publish'); |
|
| 509 | 509 | sleep(1); |
| 510 | - wpinv_insert_payment_note( $parent_invoice_id, sprintf( __( 'PayPal Subscription ID: %s', 'invoicing' ) , $ipn_data['subscr_id'] ), '', '', true ); |
|
| 511 | - update_post_meta($parent_invoice_id,'_wpinv_subscr_profile_id', $ipn_data['subscr_id']); |
|
| 510 | + wpinv_insert_payment_note($parent_invoice_id, sprintf(__('PayPal Subscription ID: %s', 'invoicing'), $ipn_data['subscr_id']), '', '', true); |
|
| 511 | + update_post_meta($parent_invoice_id, '_wpinv_subscr_profile_id', $ipn_data['subscr_id']); |
|
| 512 | 512 | |
| 513 | 513 | $status = 'trialling' == $subscription->status ? 'trialling' : 'active'; |
| 514 | - $diff_days = absint( ( ( strtotime( $subscription->expiration ) - strtotime( $subscription->created ) ) / DAY_IN_SECONDS ) ); |
|
| 515 | - $created = date_i18n( 'Y-m-d H:i:s' ); |
|
| 516 | - $expiration = date_i18n( 'Y-m-d 23:59:59', ( strtotime( $created ) + ( $diff_days * DAY_IN_SECONDS ) ) ); |
|
| 514 | + $diff_days = absint(((strtotime($subscription->expiration) - strtotime($subscription->created)) / DAY_IN_SECONDS)); |
|
| 515 | + $created = date_i18n('Y-m-d H:i:s'); |
|
| 516 | + $expiration = date_i18n('Y-m-d 23:59:59', (strtotime($created) + ($diff_days * DAY_IN_SECONDS))); |
|
| 517 | 517 | |
| 518 | 518 | // Retrieve pending subscription from database and update it's status to active and set proper profile ID |
| 519 | - $subscription->update( array( 'profile_id' => $ipn_data['subscr_id'], 'status' => $status, 'created' => $created, 'expiration' => $expiration ) ); |
|
| 519 | + $subscription->update(array('profile_id' => $ipn_data['subscr_id'], 'status' => $status, 'created' => $created, 'expiration' => $expiration)); |
|
| 520 | 520 | } |
| 521 | 521 | |
| 522 | 522 | /** |
| 523 | 523 | * Process the subscription payment received IPN. |
| 524 | 524 | */ |
| 525 | -function wpinv_process_paypal_subscr_payment( $ipn_data ) { |
|
| 526 | - $parent_invoice_id = absint( $ipn_data['custom'] ); |
|
| 525 | +function wpinv_process_paypal_subscr_payment($ipn_data) { |
|
| 526 | + $parent_invoice_id = absint($ipn_data['custom']); |
|
| 527 | 527 | |
| 528 | - $parent_invoice = wpinv_get_invoice( $parent_invoice_id ); |
|
| 529 | - if ( empty( $parent_invoice ) ) { |
|
| 528 | + $parent_invoice = wpinv_get_invoice($parent_invoice_id); |
|
| 529 | + if (empty($parent_invoice)) { |
|
| 530 | 530 | return; |
| 531 | 531 | } |
| 532 | 532 | |
| 533 | - $subscription = wpinv_get_paypal_subscription( $ipn_data ); |
|
| 534 | - if ( false === $subscription ) { |
|
| 533 | + $subscription = wpinv_get_paypal_subscription($ipn_data); |
|
| 534 | + if (false === $subscription) { |
|
| 535 | 535 | return; |
| 536 | 536 | } |
| 537 | 537 | |
| 538 | - $transaction_id = wpinv_get_payment_transaction_id( $parent_invoice_id ); |
|
| 538 | + $transaction_id = wpinv_get_payment_transaction_id($parent_invoice_id); |
|
| 539 | 539 | $times_billed = $subscription->get_times_billed(); |
| 540 | - $signup_date = strtotime( $subscription->created ); |
|
| 541 | - $today = date( 'Ynd', $signup_date ) == date( 'Ynd', strtotime( $ipn_data['payment_date'] ) ); |
|
| 540 | + $signup_date = strtotime($subscription->created); |
|
| 541 | + $today = date('Ynd', $signup_date) == date('Ynd', strtotime($ipn_data['payment_date'])); |
|
| 542 | 542 | |
| 543 | 543 | // Look to see if payment is same day as signup and we have set the transaction ID on the parent payment yet. |
| 544 | - if ( (empty($times_billed) || $today) && ( !$transaction_id || $transaction_id == $parent_invoice_id ) ) { |
|
| 545 | - wpinv_update_payment_status( $parent_invoice_id, 'publish' ); |
|
| 544 | + if ((empty($times_billed) || $today) && (!$transaction_id || $transaction_id == $parent_invoice_id)) { |
|
| 545 | + wpinv_update_payment_status($parent_invoice_id, 'publish'); |
|
| 546 | 546 | sleep(1); |
| 547 | 547 | |
| 548 | 548 | // This is the very first payment |
| 549 | - wpinv_set_payment_transaction_id( $parent_invoice_id, $ipn_data['txn_id'] ); |
|
| 550 | - wpinv_insert_payment_note( $parent_invoice_id, sprintf( __( 'PayPal Transaction ID: %s', 'invoicing' ) , $ipn_data['txn_id'] ), '', '', true ); |
|
| 549 | + wpinv_set_payment_transaction_id($parent_invoice_id, $ipn_data['txn_id']); |
|
| 550 | + wpinv_insert_payment_note($parent_invoice_id, sprintf(__('PayPal Transaction ID: %s', 'invoicing'), $ipn_data['txn_id']), '', '', true); |
|
| 551 | 551 | return; |
| 552 | 552 | } |
| 553 | 553 | |
| 554 | - if ( wpinv_get_id_by_transaction_id( $ipn_data['txn_id'] ) ) { |
|
| 554 | + if (wpinv_get_id_by_transaction_id($ipn_data['txn_id'])) { |
|
| 555 | 555 | return; // Payment already recorded |
| 556 | 556 | } |
| 557 | 557 | |
| 558 | - $currency_code = strtolower( $ipn_data['mc_currency'] ); |
|
| 558 | + $currency_code = strtolower($ipn_data['mc_currency']); |
|
| 559 | 559 | |
| 560 | 560 | // verify details |
| 561 | - if ( $currency_code != strtolower( wpinv_get_currency() ) ) { |
|
| 561 | + if ($currency_code != strtolower(wpinv_get_currency())) { |
|
| 562 | 562 | // the currency code is invalid |
| 563 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Invalid currency in IPN response. IPN data: ', 'invoicing' ), json_encode( $ipn_data ) ) ); |
|
| 563 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Invalid currency in IPN response. IPN data: ', 'invoicing'), json_encode($ipn_data))); |
|
| 564 | 564 | return; |
| 565 | 565 | } |
| 566 | 566 | |
@@ -570,11 +570,11 @@ discard block |
||
| 570 | 570 | 'gateway' => 'paypal' |
| 571 | 571 | ); |
| 572 | 572 | |
| 573 | - $invoice_id = $subscription->add_payment( $args ); |
|
| 573 | + $invoice_id = $subscription->add_payment($args); |
|
| 574 | 574 | |
| 575 | - if ( $invoice_id > 0 ) { |
|
| 576 | - wpinv_insert_payment_note( $invoice_id, wp_sprintf( __( 'PayPal Transaction ID: %s', 'invoicing' ) , $ipn_data['txn_id'] ), '', '', true ); |
|
| 577 | - wpinv_insert_payment_note( $invoice_id, wp_sprintf( __( 'PayPal Subscription ID: %s', 'invoicing' ) , $ipn_data['subscr_id'] ), '', '', true ); |
|
| 575 | + if ($invoice_id > 0) { |
|
| 576 | + wpinv_insert_payment_note($invoice_id, wp_sprintf(__('PayPal Transaction ID: %s', 'invoicing'), $ipn_data['txn_id']), '', '', true); |
|
| 577 | + wpinv_insert_payment_note($invoice_id, wp_sprintf(__('PayPal Subscription ID: %s', 'invoicing'), $ipn_data['subscr_id']), '', '', true); |
|
| 578 | 578 | |
| 579 | 579 | $subscription->renew(); |
| 580 | 580 | } |
@@ -583,10 +583,10 @@ discard block |
||
| 583 | 583 | /** |
| 584 | 584 | * Process the subscription canceled IPN. |
| 585 | 585 | */ |
| 586 | -function wpinv_process_paypal_subscr_cancel( $ipn_data ) { |
|
| 587 | - $subscription = wpinv_get_paypal_subscription( $ipn_data ); |
|
| 586 | +function wpinv_process_paypal_subscr_cancel($ipn_data) { |
|
| 587 | + $subscription = wpinv_get_paypal_subscription($ipn_data); |
|
| 588 | 588 | |
| 589 | - if( false === $subscription ) { |
|
| 589 | + if (false === $subscription) { |
|
| 590 | 590 | return; |
| 591 | 591 | } |
| 592 | 592 | |
@@ -596,10 +596,10 @@ discard block |
||
| 596 | 596 | /** |
| 597 | 597 | * Process the subscription expired IPN. |
| 598 | 598 | */ |
| 599 | -function wpinv_process_paypal_subscr_eot( $ipn_data ) { |
|
| 600 | - $subscription = wpinv_get_paypal_subscription( $ipn_data ); |
|
| 599 | +function wpinv_process_paypal_subscr_eot($ipn_data) { |
|
| 600 | + $subscription = wpinv_get_paypal_subscription($ipn_data); |
|
| 601 | 601 | |
| 602 | - if( false === $subscription ) { |
|
| 602 | + if (false === $subscription) { |
|
| 603 | 603 | return; |
| 604 | 604 | } |
| 605 | 605 | |
@@ -609,40 +609,40 @@ discard block |
||
| 609 | 609 | /** |
| 610 | 610 | * Process the subscription payment failed IPN. |
| 611 | 611 | */ |
| 612 | -function wpinv_process_paypal_subscr_failed( $ipn_data ) { |
|
| 613 | - $subscription = wpinv_get_paypal_subscription( $ipn_data ); |
|
| 612 | +function wpinv_process_paypal_subscr_failed($ipn_data) { |
|
| 613 | + $subscription = wpinv_get_paypal_subscription($ipn_data); |
|
| 614 | 614 | |
| 615 | - if( false === $subscription ) { |
|
| 615 | + if (false === $subscription) { |
|
| 616 | 616 | return; |
| 617 | 617 | } |
| 618 | 618 | |
| 619 | 619 | $subscription->failing(); |
| 620 | 620 | |
| 621 | - do_action( 'wpinv_recurring_payment_failed', $subscription ); |
|
| 621 | + do_action('wpinv_recurring_payment_failed', $subscription); |
|
| 622 | 622 | } |
| 623 | 623 | |
| 624 | 624 | /** |
| 625 | 625 | * Retrieve the subscription this IPN notice is for. |
| 626 | 626 | */ |
| 627 | -function wpinv_get_paypal_subscription( $ipn_data = array() ) { |
|
| 628 | - $parent_invoice_id = absint( $ipn_data['custom'] ); |
|
| 627 | +function wpinv_get_paypal_subscription($ipn_data = array()) { |
|
| 628 | + $parent_invoice_id = absint($ipn_data['custom']); |
|
| 629 | 629 | |
| 630 | - if( empty( $parent_invoice_id ) ) { |
|
| 630 | + if (empty($parent_invoice_id)) { |
|
| 631 | 631 | return false; |
| 632 | 632 | } |
| 633 | 633 | |
| 634 | - $invoice = wpinv_get_invoice( $parent_invoice_id ); |
|
| 635 | - if ( empty( $invoice ) ) { |
|
| 634 | + $invoice = wpinv_get_invoice($parent_invoice_id); |
|
| 635 | + if (empty($invoice)) { |
|
| 636 | 636 | return false; |
| 637 | 637 | } |
| 638 | 638 | |
| 639 | - $subscription = new WPInv_Subscription( $ipn_data['subscr_id'], true ); |
|
| 639 | + $subscription = new WPInv_Subscription($ipn_data['subscr_id'], true); |
|
| 640 | 640 | |
| 641 | - if ( ! ( ! empty( $subscription ) && $subscription->id > 0 ) ) { |
|
| 642 | - $subscription = wpinv_get_subscription( $parent_invoice_id ); |
|
| 641 | + if (!(!empty($subscription) && $subscription->id > 0)) { |
|
| 642 | + $subscription = wpinv_get_subscription($parent_invoice_id); |
|
| 643 | 643 | |
| 644 | - if ( ! empty( $subscription ) && $subscription->id > 0 ) { |
|
| 645 | - $subscription->update( array( 'profile_id' => sanitize_text_field( $ipn_data['subscr_id'] ) ) ); |
|
| 644 | + if (!empty($subscription) && $subscription->id > 0) { |
|
| 645 | + $subscription->update(array('profile_id' => sanitize_text_field($ipn_data['subscr_id']))); |
|
| 646 | 646 | } else { |
| 647 | 647 | return false; |
| 648 | 648 | } |
@@ -652,152 +652,152 @@ discard block |
||
| 652 | 652 | |
| 653 | 653 | } |
| 654 | 654 | |
| 655 | -function wpinv_process_paypal_refund( $data, $invoice_id = 0 ) { |
|
| 655 | +function wpinv_process_paypal_refund($data, $invoice_id = 0) { |
|
| 656 | 656 | // Collect payment details |
| 657 | 657 | |
| 658 | - if( empty( $invoice_id ) ) { |
|
| 658 | + if (empty($invoice_id)) { |
|
| 659 | 659 | return; |
| 660 | 660 | } |
| 661 | 661 | |
| 662 | - if ( get_post_status( $invoice_id ) == 'wpi-refunded' ) { |
|
| 662 | + if (get_post_status($invoice_id) == 'wpi-refunded') { |
|
| 663 | 663 | return; // Only refund payments once |
| 664 | 664 | } |
| 665 | 665 | |
| 666 | - $payment_amount = wpinv_payment_total( $invoice_id ); |
|
| 666 | + $payment_amount = wpinv_payment_total($invoice_id); |
|
| 667 | 667 | $refund_amount = $data['mc_gross'] * -1; |
| 668 | 668 | |
| 669 | - do_action( 'wpinv_paypal_refund_request', $data, $invoice_id ); |
|
| 669 | + do_action('wpinv_paypal_refund_request', $data, $invoice_id); |
|
| 670 | 670 | |
| 671 | - if ( number_format( (float) $refund_amount, 2 ) < number_format( (float) $payment_amount, 2 ) ) { |
|
| 672 | - wpinv_insert_payment_note( $invoice_id, wp_sprintf( __( 'PayPal partial refund of %s processed for transaction #%s for reason: %s', 'invoicing' ), (float)$refund_amount . ' '. $data['mc_currency'], $data['parent_txn_id'], $data['reason_code'] ), '', '', true ); |
|
| 671 | + if (number_format((float) $refund_amount, 2) < number_format((float) $payment_amount, 2)) { |
|
| 672 | + wpinv_insert_payment_note($invoice_id, wp_sprintf(__('PayPal partial refund of %s processed for transaction #%s for reason: %s', 'invoicing'), (float) $refund_amount . ' ' . $data['mc_currency'], $data['parent_txn_id'], $data['reason_code']), '', '', true); |
|
| 673 | 673 | |
| 674 | - do_action( 'wpinv_paypal_invoice_partially_refunded', $data, $invoice_id, $refund_amount ); |
|
| 674 | + do_action('wpinv_paypal_invoice_partially_refunded', $data, $invoice_id, $refund_amount); |
|
| 675 | 675 | |
| 676 | 676 | return; // This is a partial refund |
| 677 | 677 | } |
| 678 | 678 | |
| 679 | - wpinv_insert_payment_note( $invoice_id, sprintf( __( 'PayPal Payment #%s Refunded for reason: %s', 'invoicing' ), $data['parent_txn_id'], $data['reason_code'] ), '', '', true ); |
|
| 680 | - wpinv_insert_payment_note( $invoice_id, sprintf( __( 'PayPal Refund Transaction ID: %s', 'invoicing' ), $data['txn_id'] ), '', '', true ); |
|
| 681 | - wpinv_update_payment_status( $invoice_id, 'wpi-refunded' ); |
|
| 679 | + wpinv_insert_payment_note($invoice_id, sprintf(__('PayPal Payment #%s Refunded for reason: %s', 'invoicing'), $data['parent_txn_id'], $data['reason_code']), '', '', true); |
|
| 680 | + wpinv_insert_payment_note($invoice_id, sprintf(__('PayPal Refund Transaction ID: %s', 'invoicing'), $data['txn_id']), '', '', true); |
|
| 681 | + wpinv_update_payment_status($invoice_id, 'wpi-refunded'); |
|
| 682 | 682 | |
| 683 | - do_action( 'wpinv_paypal_invoice_fully_refunded', $data, $invoice_id ); |
|
| 683 | + do_action('wpinv_paypal_invoice_fully_refunded', $data, $invoice_id); |
|
| 684 | 684 | } |
| 685 | 685 | |
| 686 | -function wpinv_get_paypal_redirect( $ssl_check = false ) { |
|
| 687 | - return apply_filters( 'wpinv_paypal_uri', wpinv_is_test_mode( 'paypal' ) ? 'https://www.sandbox.paypal.com/cgi-bin/webscr?test_ipn=1&' : 'https://www.paypal.com/cgi-bin/webscr?' ); |
|
| 686 | +function wpinv_get_paypal_redirect($ssl_check = false) { |
|
| 687 | + return apply_filters('wpinv_paypal_uri', wpinv_is_test_mode('paypal') ? 'https://www.sandbox.paypal.com/cgi-bin/webscr?test_ipn=1&' : 'https://www.paypal.com/cgi-bin/webscr?'); |
|
| 688 | 688 | } |
| 689 | 689 | |
| 690 | -function wpinv_paypal_success_page_content( $content ) { |
|
| 690 | +function wpinv_paypal_success_page_content($content) { |
|
| 691 | 691 | global $wpi_invoice; |
| 692 | 692 | |
| 693 | 693 | $session = wpinv_get_checkout_session(); |
| 694 | 694 | |
| 695 | - if ( empty( $_GET['invoice-id'] ) && empty( $session['invoice_key'] ) ) { |
|
| 695 | + if (empty($_GET['invoice-id']) && empty($session['invoice_key'])) { |
|
| 696 | 696 | return $content; |
| 697 | 697 | } |
| 698 | 698 | |
| 699 | - $invoice_id = ! empty( $_GET['invoice-id'] ) ? absint( $_GET['invoice-id'] ) : wpinv_get_invoice_id_by_key( $session['invoice_key'] ); |
|
| 699 | + $invoice_id = !empty($_GET['invoice-id']) ? absint($_GET['invoice-id']) : wpinv_get_invoice_id_by_key($session['invoice_key']); |
|
| 700 | 700 | |
| 701 | - if ( empty( $invoice_id ) ) { |
|
| 701 | + if (empty($invoice_id)) { |
|
| 702 | 702 | return $content; |
| 703 | 703 | } |
| 704 | 704 | |
| 705 | - $wpi_invoice = wpinv_get_invoice( $invoice_id ); |
|
| 705 | + $wpi_invoice = wpinv_get_invoice($invoice_id); |
|
| 706 | 706 | |
| 707 | - if ( ! empty( $wpi_invoice ) && 'wpi-pending' == $wpi_invoice->status ) { |
|
| 707 | + if (!empty($wpi_invoice) && 'wpi-pending' == $wpi_invoice->status) { |
|
| 708 | 708 | // Payment is still pending so show processing indicator to fix the Race Condition, issue # |
| 709 | 709 | ob_start(); |
| 710 | - wpinv_get_template_part( 'wpinv-payment-processing' ); |
|
| 710 | + wpinv_get_template_part('wpinv-payment-processing'); |
|
| 711 | 711 | $content = ob_get_clean(); |
| 712 | 712 | } |
| 713 | 713 | |
| 714 | 714 | return $content; |
| 715 | 715 | } |
| 716 | -add_filter( 'wpinv_payment_confirm_paypal', 'wpinv_paypal_success_page_content' ); |
|
| 716 | +add_filter('wpinv_payment_confirm_paypal', 'wpinv_paypal_success_page_content'); |
|
| 717 | 717 | |
| 718 | -function wpinv_paypal_get_transaction_id( $invoice_id ) { |
|
| 718 | +function wpinv_paypal_get_transaction_id($invoice_id) { |
|
| 719 | 719 | $transaction_id = ''; |
| 720 | - $notes = wpinv_get_invoice_notes( $invoice_id ); |
|
| 720 | + $notes = wpinv_get_invoice_notes($invoice_id); |
|
| 721 | 721 | |
| 722 | - foreach ( $notes as $note ) { |
|
| 723 | - if ( preg_match( '/^PayPal Transaction ID: ([^\s]+)/', $note->comment_content, $match ) ) { |
|
| 722 | + foreach ($notes as $note) { |
|
| 723 | + if (preg_match('/^PayPal Transaction ID: ([^\s]+)/', $note->comment_content, $match)) { |
|
| 724 | 724 | $transaction_id = $match[1]; |
| 725 | 725 | continue; |
| 726 | 726 | } |
| 727 | 727 | } |
| 728 | 728 | |
| 729 | - return apply_filters( 'wpinv_paypal_set_transaction_id', $transaction_id, $invoice_id ); |
|
| 729 | + return apply_filters('wpinv_paypal_set_transaction_id', $transaction_id, $invoice_id); |
|
| 730 | 730 | } |
| 731 | -add_filter( 'wpinv_payment_get_transaction_id-paypal', 'wpinv_paypal_get_transaction_id', 10, 1 ); |
|
| 731 | +add_filter('wpinv_payment_get_transaction_id-paypal', 'wpinv_paypal_get_transaction_id', 10, 1); |
|
| 732 | 732 | |
| 733 | -function wpinv_paypal_link_transaction_id( $transaction_id, $invoice_id, $invoice ) { |
|
| 734 | - if ( $transaction_id == $invoice_id ) { |
|
| 733 | +function wpinv_paypal_link_transaction_id($transaction_id, $invoice_id, $invoice) { |
|
| 734 | + if ($transaction_id == $invoice_id) { |
|
| 735 | 735 | $transaction_link = $transaction_id; |
| 736 | 736 | } else { |
| 737 | - if ( ! empty( $invoice ) && ! empty( $invoice->mode ) ) { |
|
| 737 | + if (!empty($invoice) && !empty($invoice->mode)) { |
|
| 738 | 738 | $mode = $invoice->mode; |
| 739 | 739 | } else { |
| 740 | - $mode = wpinv_is_test_mode( 'paypal' ) ? 'test' : 'live'; |
|
| 740 | + $mode = wpinv_is_test_mode('paypal') ? 'test' : 'live'; |
|
| 741 | 741 | } |
| 742 | 742 | |
| 743 | 743 | $sandbox = $mode == 'test' ? '.sandbox' : ''; |
| 744 | 744 | $transaction_url = 'https://www' . $sandbox . '.paypal.com/webscr?cmd=_history-details-from-hub&id=' . $transaction_id; |
| 745 | 745 | |
| 746 | - $transaction_link = '<a href="' . esc_url( $transaction_url ) . '" target="_blank">' . $transaction_id . '</a>'; |
|
| 746 | + $transaction_link = '<a href="' . esc_url($transaction_url) . '" target="_blank">' . $transaction_id . '</a>'; |
|
| 747 | 747 | } |
| 748 | 748 | |
| 749 | - return apply_filters( 'wpinv_paypal_link_payment_details_transaction_id', $transaction_link, $transaction_id, $invoice ); |
|
| 749 | + return apply_filters('wpinv_paypal_link_payment_details_transaction_id', $transaction_link, $transaction_id, $invoice); |
|
| 750 | 750 | } |
| 751 | -add_filter( 'wpinv_payment_details_transaction_id-paypal', 'wpinv_paypal_link_transaction_id', 10, 3 ); |
|
| 751 | +add_filter('wpinv_payment_details_transaction_id-paypal', 'wpinv_paypal_link_transaction_id', 10, 3); |
|
| 752 | 752 | |
| 753 | -function wpinv_paypal_profile_id_link( $profile_id, $subscription ) { |
|
| 753 | +function wpinv_paypal_profile_id_link($profile_id, $subscription) { |
|
| 754 | 754 | $link = $profile_id; |
| 755 | 755 | |
| 756 | - if ( ! empty( $profile_id ) && ! empty( $subscription ) && ( $invoice_id = $subscription->get_original_payment_id() ) ) { |
|
| 757 | - $invoice = wpinv_get_invoice( $invoice_id ); |
|
| 756 | + if (!empty($profile_id) && !empty($subscription) && ($invoice_id = $subscription->get_original_payment_id())) { |
|
| 757 | + $invoice = wpinv_get_invoice($invoice_id); |
|
| 758 | 758 | |
| 759 | - if ( ! empty( $invoice ) && ! empty( $invoice->mode ) ) { |
|
| 759 | + if (!empty($invoice) && !empty($invoice->mode)) { |
|
| 760 | 760 | $mode = $invoice->mode; |
| 761 | 761 | } else { |
| 762 | - $mode = wpinv_is_test_mode( 'paypal' ) ? 'test' : 'live'; |
|
| 762 | + $mode = wpinv_is_test_mode('paypal') ? 'test' : 'live'; |
|
| 763 | 763 | } |
| 764 | 764 | |
| 765 | 765 | $sandbox = $mode == 'test' ? '.sandbox' : ''; |
| 766 | 766 | $url = 'https://www' . $sandbox . '.paypal.com/cgi-bin/webscr?cmd=_profile-recurring-payments&encrypted_profile_id=' . $profile_id; |
| 767 | 767 | |
| 768 | - $link = '<a href="' . esc_url( $url ) . '" target="_blank">' . $profile_id . '</a>'; |
|
| 768 | + $link = '<a href="' . esc_url($url) . '" target="_blank">' . $profile_id . '</a>'; |
|
| 769 | 769 | } |
| 770 | 770 | |
| 771 | - return apply_filters( 'wpinv_paypal_profile_id_link', $link, $profile_id, $subscription ); |
|
| 771 | + return apply_filters('wpinv_paypal_profile_id_link', $link, $profile_id, $subscription); |
|
| 772 | 772 | } |
| 773 | -add_filter( 'wpinv_subscription_profile_link_paypal', 'wpinv_paypal_profile_id_link', 10, 2 ); |
|
| 773 | +add_filter('wpinv_subscription_profile_link_paypal', 'wpinv_paypal_profile_id_link', 10, 2); |
|
| 774 | 774 | |
| 775 | -function wpinv_paypal_transaction_id_link( $transaction_id, $subscription ) { |
|
| 776 | - if ( ! empty( $transaction_id ) && ! empty( $subscription ) && ( $invoice_id = $subscription->get_original_payment_id() ) ) { |
|
| 777 | - $invoice = wpinv_get_invoice( $invoice_id ); |
|
| 775 | +function wpinv_paypal_transaction_id_link($transaction_id, $subscription) { |
|
| 776 | + if (!empty($transaction_id) && !empty($subscription) && ($invoice_id = $subscription->get_original_payment_id())) { |
|
| 777 | + $invoice = wpinv_get_invoice($invoice_id); |
|
| 778 | 778 | |
| 779 | - if ( ! empty( $invoice ) ) { |
|
| 780 | - return wpinv_paypal_link_transaction_id( $transaction_id, $invoice_id, $invoice ); |
|
| 779 | + if (!empty($invoice)) { |
|
| 780 | + return wpinv_paypal_link_transaction_id($transaction_id, $invoice_id, $invoice); |
|
| 781 | 781 | } |
| 782 | 782 | } |
| 783 | 783 | |
| 784 | 784 | return $transaction_id; |
| 785 | 785 | } |
| 786 | -add_filter( 'wpinv_subscription_transaction_link_paypal', 'wpinv_paypal_transaction_id_link', 10, 2 ); |
|
| 786 | +add_filter('wpinv_subscription_transaction_link_paypal', 'wpinv_paypal_transaction_id_link', 10, 2); |
|
| 787 | 787 | |
| 788 | 788 | function wpinv_is_paypal_valid_for_use() { |
| 789 | - return in_array( wpinv_get_currency(), apply_filters( 'wpinv_paypal_supported_currencies', array( 'AUD', 'BRL', 'CAD', 'MXN', 'NZD', 'HKD', 'SGD', 'USD', 'EUR', 'JPY', 'TRY', 'NOK', 'CZK', 'DKK', 'HUF', 'ILS', 'MYR', 'PHP', 'PLN', 'SEK', 'CHF', 'TWD', 'THB', 'GBP', 'RMB', 'RUB', 'INR' ) ) ); |
|
| 789 | + return in_array(wpinv_get_currency(), apply_filters('wpinv_paypal_supported_currencies', array('AUD', 'BRL', 'CAD', 'MXN', 'NZD', 'HKD', 'SGD', 'USD', 'EUR', 'JPY', 'TRY', 'NOK', 'CZK', 'DKK', 'HUF', 'ILS', 'MYR', 'PHP', 'PLN', 'SEK', 'CHF', 'TWD', 'THB', 'GBP', 'RMB', 'RUB', 'INR'))); |
|
| 790 | 790 | } |
| 791 | 791 | |
| 792 | -function wpinv_check_paypal_currency_support( $gateway_list ) { |
|
| 793 | - if ( isset( $gateway_list['paypal'] ) && ! wpinv_is_paypal_valid_for_use() ) { |
|
| 794 | - unset( $gateway_list['paypal'] ); |
|
| 792 | +function wpinv_check_paypal_currency_support($gateway_list) { |
|
| 793 | + if (isset($gateway_list['paypal']) && !wpinv_is_paypal_valid_for_use()) { |
|
| 794 | + unset($gateway_list['paypal']); |
|
| 795 | 795 | } |
| 796 | 796 | return $gateway_list; |
| 797 | 797 | } |
| 798 | -add_filter( 'wpinv_enabled_payment_gateways', 'wpinv_check_paypal_currency_support', 10, 1 ); |
|
| 798 | +add_filter('wpinv_enabled_payment_gateways', 'wpinv_check_paypal_currency_support', 10, 1); |
|
| 799 | 799 | |
| 800 | -function wpinv_gateway_paypal_button_label( $label ) { |
|
| 801 | - return __( 'Proceed to PayPal', 'invoicing' ); |
|
| 800 | +function wpinv_gateway_paypal_button_label($label) { |
|
| 801 | + return __('Proceed to PayPal', 'invoicing'); |
|
| 802 | 802 | } |
| 803 | -add_filter( 'wpinv_gateway_paypal_button_label', 'wpinv_gateway_paypal_button_label', 10, 1 ); |
|
| 804 | 803 | \ No newline at end of file |
| 804 | +add_filter('wpinv_gateway_paypal_button_label', 'wpinv_gateway_paypal_button_label', 10, 1); |
|
| 805 | 805 | \ No newline at end of file |
@@ -12,125 +12,125 @@ discard block |
||
| 12 | 12 | */ |
| 13 | 13 | class WPInv_Session_Handler extends WPInv_Session { |
| 14 | 14 | |
| 15 | - /** |
|
| 16 | - * Cookie name used for the session. |
|
| 17 | - * |
|
| 18 | - * @var string cookie name |
|
| 19 | - */ |
|
| 20 | - protected $_cookie; |
|
| 21 | - |
|
| 22 | - /** |
|
| 23 | - * Stores session expiry. |
|
| 24 | - * |
|
| 25 | - * @var int session due to expire timestamp |
|
| 26 | - */ |
|
| 27 | - protected $_session_expiring; |
|
| 28 | - |
|
| 29 | - /** |
|
| 30 | - * Stores session due to expire timestamp. |
|
| 31 | - * |
|
| 32 | - * @var string session expiration timestamp |
|
| 33 | - */ |
|
| 34 | - protected $_session_expiration; |
|
| 35 | - |
|
| 36 | - /** |
|
| 37 | - * True when the cookie exists. |
|
| 38 | - * |
|
| 39 | - * @var bool Based on whether a cookie exists. |
|
| 40 | - */ |
|
| 41 | - protected $_has_cookie = false; |
|
| 42 | - |
|
| 43 | - /** |
|
| 44 | - * Table name for session data. |
|
| 45 | - * |
|
| 46 | - * @var string Custom session table name |
|
| 47 | - */ |
|
| 48 | - protected $_table; |
|
| 49 | - |
|
| 50 | - /** |
|
| 51 | - * Constructor for the session class. |
|
| 52 | - */ |
|
| 53 | - public function __construct() { |
|
| 54 | - |
|
| 55 | - $this->_cookie = apply_filters( 'wpinv_cookie', 'wpinv_session_' . COOKIEHASH ); |
|
| 15 | + /** |
|
| 16 | + * Cookie name used for the session. |
|
| 17 | + * |
|
| 18 | + * @var string cookie name |
|
| 19 | + */ |
|
| 20 | + protected $_cookie; |
|
| 21 | + |
|
| 22 | + /** |
|
| 23 | + * Stores session expiry. |
|
| 24 | + * |
|
| 25 | + * @var int session due to expire timestamp |
|
| 26 | + */ |
|
| 27 | + protected $_session_expiring; |
|
| 28 | + |
|
| 29 | + /** |
|
| 30 | + * Stores session due to expire timestamp. |
|
| 31 | + * |
|
| 32 | + * @var string session expiration timestamp |
|
| 33 | + */ |
|
| 34 | + protected $_session_expiration; |
|
| 35 | + |
|
| 36 | + /** |
|
| 37 | + * True when the cookie exists. |
|
| 38 | + * |
|
| 39 | + * @var bool Based on whether a cookie exists. |
|
| 40 | + */ |
|
| 41 | + protected $_has_cookie = false; |
|
| 42 | + |
|
| 43 | + /** |
|
| 44 | + * Table name for session data. |
|
| 45 | + * |
|
| 46 | + * @var string Custom session table name |
|
| 47 | + */ |
|
| 48 | + protected $_table; |
|
| 49 | + |
|
| 50 | + /** |
|
| 51 | + * Constructor for the session class. |
|
| 52 | + */ |
|
| 53 | + public function __construct() { |
|
| 54 | + |
|
| 55 | + $this->_cookie = apply_filters( 'wpinv_cookie', 'wpinv_session_' . COOKIEHASH ); |
|
| 56 | 56 | add_action( 'init', array( $this, 'init' ), -1 ); |
| 57 | - add_action( 'wp_logout', array( $this, 'destroy_session' ) ); |
|
| 58 | - add_action( 'wp', array( $this, 'set_customer_session_cookie' ), 10 ); |
|
| 59 | - add_action( 'shutdown', array( $this, 'save_data' ), 20 ); |
|
| 60 | - |
|
| 61 | - } |
|
| 62 | - |
|
| 63 | - /** |
|
| 64 | - * Init hooks and session data. |
|
| 65 | - * |
|
| 66 | - * @since 3.3.0 |
|
| 67 | - */ |
|
| 68 | - public function init() { |
|
| 69 | - $this->init_session_cookie(); |
|
| 70 | - |
|
| 71 | - if ( ! is_user_logged_in() ) { |
|
| 72 | - add_filter( 'nonce_user_logged_out', array( $this, 'nonce_user_logged_out' ) ); |
|
| 73 | - } |
|
| 74 | - } |
|
| 75 | - |
|
| 76 | - /** |
|
| 77 | - * Setup cookie and customer ID. |
|
| 78 | - * |
|
| 79 | - * @since 3.6.0 |
|
| 80 | - */ |
|
| 81 | - public function init_session_cookie() { |
|
| 82 | - $cookie = $this->get_session_cookie(); |
|
| 83 | - |
|
| 84 | - if ( $cookie ) { |
|
| 85 | - $this->_customer_id = $cookie[0]; |
|
| 86 | - $this->_session_expiration = $cookie[1]; |
|
| 87 | - $this->_session_expiring = $cookie[2]; |
|
| 88 | - $this->_has_cookie = true; |
|
| 89 | - $this->_data = $this->get_session_data(); |
|
| 90 | - |
|
| 91 | - // If the user logs in, update session. |
|
| 92 | - if ( is_user_logged_in() && get_current_user_id() != $this->_customer_id ) { |
|
| 93 | - $this->_customer_id = get_current_user_id(); |
|
| 94 | - $this->_dirty = true; |
|
| 95 | - $this->save_data(); |
|
| 96 | - $this->set_customer_session_cookie( true ); |
|
| 97 | - } |
|
| 98 | - |
|
| 99 | - // Update session if its close to expiring. |
|
| 100 | - if ( time() > $this->_session_expiring ) { |
|
| 101 | - $this->set_session_expiration(); |
|
| 102 | - $this->update_session_timestamp( $this->_customer_id, $this->_session_expiration ); |
|
| 103 | - } |
|
| 104 | - } else { |
|
| 105 | - $this->set_session_expiration(); |
|
| 106 | - $this->_customer_id = $this->generate_customer_id(); |
|
| 107 | - $this->_data = $this->get_session_data(); |
|
| 108 | - } |
|
| 109 | - } |
|
| 110 | - |
|
| 111 | - /** |
|
| 112 | - * Sets the session cookie on-demand (usually after adding an item to the cart). |
|
| 113 | - * |
|
| 114 | - * Since the cookie name (as of 2.1) is prepended with wp, cache systems like batcache will not cache pages when set. |
|
| 115 | - * |
|
| 116 | - * Warning: Cookies will only be set if this is called before the headers are sent. |
|
| 117 | - * |
|
| 118 | - * @param bool $set Should the session cookie be set. |
|
| 119 | - */ |
|
| 120 | - public function set_customer_session_cookie( $set ) { |
|
| 121 | - if ( $set ) { |
|
| 122 | - $to_hash = $this->_customer_id . '|' . $this->_session_expiration; |
|
| 123 | - $cookie_hash = hash_hmac( 'md5', $to_hash, wp_hash( $to_hash ) ); |
|
| 124 | - $cookie_value = $this->_customer_id . '||' . $this->_session_expiration . '||' . $this->_session_expiring . '||' . $cookie_hash; |
|
| 125 | - $this->_has_cookie = true; |
|
| 126 | - |
|
| 127 | - if ( ! isset( $_COOKIE[ $this->_cookie ] ) || $_COOKIE[ $this->_cookie ] !== $cookie_value ) { |
|
| 128 | - $this->setcookie( $this->_cookie, $cookie_value, $this->_session_expiration, $this->use_secure_cookie(), true ); |
|
| 129 | - } |
|
| 130 | - } |
|
| 131 | - } |
|
| 132 | - |
|
| 133 | - public function setcookie($name, $value, $expire = 0, $secure = false, $httponly = false){ |
|
| 57 | + add_action( 'wp_logout', array( $this, 'destroy_session' ) ); |
|
| 58 | + add_action( 'wp', array( $this, 'set_customer_session_cookie' ), 10 ); |
|
| 59 | + add_action( 'shutdown', array( $this, 'save_data' ), 20 ); |
|
| 60 | + |
|
| 61 | + } |
|
| 62 | + |
|
| 63 | + /** |
|
| 64 | + * Init hooks and session data. |
|
| 65 | + * |
|
| 66 | + * @since 3.3.0 |
|
| 67 | + */ |
|
| 68 | + public function init() { |
|
| 69 | + $this->init_session_cookie(); |
|
| 70 | + |
|
| 71 | + if ( ! is_user_logged_in() ) { |
|
| 72 | + add_filter( 'nonce_user_logged_out', array( $this, 'nonce_user_logged_out' ) ); |
|
| 73 | + } |
|
| 74 | + } |
|
| 75 | + |
|
| 76 | + /** |
|
| 77 | + * Setup cookie and customer ID. |
|
| 78 | + * |
|
| 79 | + * @since 3.6.0 |
|
| 80 | + */ |
|
| 81 | + public function init_session_cookie() { |
|
| 82 | + $cookie = $this->get_session_cookie(); |
|
| 83 | + |
|
| 84 | + if ( $cookie ) { |
|
| 85 | + $this->_customer_id = $cookie[0]; |
|
| 86 | + $this->_session_expiration = $cookie[1]; |
|
| 87 | + $this->_session_expiring = $cookie[2]; |
|
| 88 | + $this->_has_cookie = true; |
|
| 89 | + $this->_data = $this->get_session_data(); |
|
| 90 | + |
|
| 91 | + // If the user logs in, update session. |
|
| 92 | + if ( is_user_logged_in() && get_current_user_id() != $this->_customer_id ) { |
|
| 93 | + $this->_customer_id = get_current_user_id(); |
|
| 94 | + $this->_dirty = true; |
|
| 95 | + $this->save_data(); |
|
| 96 | + $this->set_customer_session_cookie( true ); |
|
| 97 | + } |
|
| 98 | + |
|
| 99 | + // Update session if its close to expiring. |
|
| 100 | + if ( time() > $this->_session_expiring ) { |
|
| 101 | + $this->set_session_expiration(); |
|
| 102 | + $this->update_session_timestamp( $this->_customer_id, $this->_session_expiration ); |
|
| 103 | + } |
|
| 104 | + } else { |
|
| 105 | + $this->set_session_expiration(); |
|
| 106 | + $this->_customer_id = $this->generate_customer_id(); |
|
| 107 | + $this->_data = $this->get_session_data(); |
|
| 108 | + } |
|
| 109 | + } |
|
| 110 | + |
|
| 111 | + /** |
|
| 112 | + * Sets the session cookie on-demand (usually after adding an item to the cart). |
|
| 113 | + * |
|
| 114 | + * Since the cookie name (as of 2.1) is prepended with wp, cache systems like batcache will not cache pages when set. |
|
| 115 | + * |
|
| 116 | + * Warning: Cookies will only be set if this is called before the headers are sent. |
|
| 117 | + * |
|
| 118 | + * @param bool $set Should the session cookie be set. |
|
| 119 | + */ |
|
| 120 | + public function set_customer_session_cookie( $set ) { |
|
| 121 | + if ( $set ) { |
|
| 122 | + $to_hash = $this->_customer_id . '|' . $this->_session_expiration; |
|
| 123 | + $cookie_hash = hash_hmac( 'md5', $to_hash, wp_hash( $to_hash ) ); |
|
| 124 | + $cookie_value = $this->_customer_id . '||' . $this->_session_expiration . '||' . $this->_session_expiring . '||' . $cookie_hash; |
|
| 125 | + $this->_has_cookie = true; |
|
| 126 | + |
|
| 127 | + if ( ! isset( $_COOKIE[ $this->_cookie ] ) || $_COOKIE[ $this->_cookie ] !== $cookie_value ) { |
|
| 128 | + $this->setcookie( $this->_cookie, $cookie_value, $this->_session_expiration, $this->use_secure_cookie(), true ); |
|
| 129 | + } |
|
| 130 | + } |
|
| 131 | + } |
|
| 132 | + |
|
| 133 | + public function setcookie($name, $value, $expire = 0, $secure = false, $httponly = false){ |
|
| 134 | 134 | if ( ! headers_sent() ) { |
| 135 | 135 | setcookie( $name, $value, $expire, COOKIEPATH ? COOKIEPATH : '/', COOKIE_DOMAIN, $secure, apply_filters( 'wpinv_cookie_httponly', $httponly, $name, $value, $expire, $secure ) ); |
| 136 | 136 | } elseif ( defined( 'WP_DEBUG' ) && WP_DEBUG ) { |
@@ -139,86 +139,86 @@ discard block |
||
| 139 | 139 | } |
| 140 | 140 | } |
| 141 | 141 | |
| 142 | - /** |
|
| 143 | - * Should the session cookie be secure? |
|
| 144 | - * |
|
| 145 | - * @since 3.6.0 |
|
| 146 | - * @return bool |
|
| 147 | - */ |
|
| 148 | - protected function use_secure_cookie() { |
|
| 142 | + /** |
|
| 143 | + * Should the session cookie be secure? |
|
| 144 | + * |
|
| 145 | + * @since 3.6.0 |
|
| 146 | + * @return bool |
|
| 147 | + */ |
|
| 148 | + protected function use_secure_cookie() { |
|
| 149 | 149 | $is_https = false !== strstr( get_option( 'home' ), 'https:' ); |
| 150 | - return apply_filters( 'wpinv_session_use_secure_cookie', $is_https && is_ssl() ); |
|
| 151 | - } |
|
| 152 | - |
|
| 153 | - /** |
|
| 154 | - * Return true if the current user has an active session, i.e. a cookie to retrieve values. |
|
| 155 | - * |
|
| 156 | - * @return bool |
|
| 157 | - */ |
|
| 158 | - public function has_session() { |
|
| 159 | - return isset( $_COOKIE[ $this->_cookie ] ) || $this->_has_cookie || is_user_logged_in(); // @codingStandardsIgnoreLine. |
|
| 160 | - } |
|
| 161 | - |
|
| 162 | - /** |
|
| 163 | - * Set session expiration. |
|
| 164 | - */ |
|
| 165 | - public function set_session_expiration() { |
|
| 166 | - $this->_session_expiring = time() + intval( apply_filters( 'wpinv_session_expiring', 60 * 60 * 47 ) ); // 47 Hours. |
|
| 167 | - $this->_session_expiration = time() + intval( apply_filters( 'wpinv_session_expiration', 60 * 60 * 48 ) ); // 48 Hours. |
|
| 168 | - } |
|
| 169 | - |
|
| 170 | - /** |
|
| 171 | - * Generates session ids. |
|
| 172 | - * |
|
| 173 | - * @return string |
|
| 174 | - */ |
|
| 175 | - public function generate_customer_id() { |
|
| 176 | - require_once ABSPATH . 'wp-includes/class-phpass.php'; |
|
| 177 | - $hasher = new PasswordHash( 8, false ); |
|
| 178 | - return md5( $hasher->get_random_bytes( 32 ) ); |
|
| 179 | - } |
|
| 180 | - |
|
| 181 | - /** |
|
| 182 | - * Get the session cookie, if set. Otherwise return false. |
|
| 183 | - * |
|
| 184 | - * Session cookies without a customer ID are invalid. |
|
| 185 | - * |
|
| 186 | - * @return bool|array |
|
| 187 | - */ |
|
| 188 | - public function get_session_cookie() { |
|
| 189 | - $cookie_value = isset( $_COOKIE[ $this->_cookie ] ) ? wp_unslash( $_COOKIE[ $this->_cookie ] ) : false; // @codingStandardsIgnoreLine. |
|
| 190 | - |
|
| 191 | - if ( empty( $cookie_value ) || ! is_string( $cookie_value ) ) { |
|
| 192 | - return false; |
|
| 193 | - } |
|
| 194 | - |
|
| 195 | - list( $customer_id, $session_expiration, $session_expiring, $cookie_hash ) = explode( '||', $cookie_value ); |
|
| 196 | - |
|
| 197 | - if ( empty( $customer_id ) ) { |
|
| 198 | - return false; |
|
| 199 | - } |
|
| 200 | - |
|
| 201 | - // Validate hash. |
|
| 202 | - $to_hash = $customer_id . '|' . $session_expiration; |
|
| 203 | - $hash = hash_hmac( 'md5', $to_hash, wp_hash( $to_hash ) ); |
|
| 204 | - |
|
| 205 | - if ( empty( $cookie_hash ) || ! hash_equals( $hash, $cookie_hash ) ) { |
|
| 206 | - return false; |
|
| 207 | - } |
|
| 208 | - |
|
| 209 | - return array( $customer_id, $session_expiration, $session_expiring, $cookie_hash ); |
|
| 210 | - } |
|
| 211 | - |
|
| 212 | - /** |
|
| 213 | - * Get session data. |
|
| 214 | - * |
|
| 215 | - * @return array |
|
| 216 | - */ |
|
| 217 | - public function get_session_data() { |
|
| 218 | - return $this->has_session() ? (array) $this->get_session( $this->_customer_id ) : array(); |
|
| 219 | - } |
|
| 220 | - |
|
| 221 | - public function generate_key($customer_id){ |
|
| 150 | + return apply_filters( 'wpinv_session_use_secure_cookie', $is_https && is_ssl() ); |
|
| 151 | + } |
|
| 152 | + |
|
| 153 | + /** |
|
| 154 | + * Return true if the current user has an active session, i.e. a cookie to retrieve values. |
|
| 155 | + * |
|
| 156 | + * @return bool |
|
| 157 | + */ |
|
| 158 | + public function has_session() { |
|
| 159 | + return isset( $_COOKIE[ $this->_cookie ] ) || $this->_has_cookie || is_user_logged_in(); // @codingStandardsIgnoreLine. |
|
| 160 | + } |
|
| 161 | + |
|
| 162 | + /** |
|
| 163 | + * Set session expiration. |
|
| 164 | + */ |
|
| 165 | + public function set_session_expiration() { |
|
| 166 | + $this->_session_expiring = time() + intval( apply_filters( 'wpinv_session_expiring', 60 * 60 * 47 ) ); // 47 Hours. |
|
| 167 | + $this->_session_expiration = time() + intval( apply_filters( 'wpinv_session_expiration', 60 * 60 * 48 ) ); // 48 Hours. |
|
| 168 | + } |
|
| 169 | + |
|
| 170 | + /** |
|
| 171 | + * Generates session ids. |
|
| 172 | + * |
|
| 173 | + * @return string |
|
| 174 | + */ |
|
| 175 | + public function generate_customer_id() { |
|
| 176 | + require_once ABSPATH . 'wp-includes/class-phpass.php'; |
|
| 177 | + $hasher = new PasswordHash( 8, false ); |
|
| 178 | + return md5( $hasher->get_random_bytes( 32 ) ); |
|
| 179 | + } |
|
| 180 | + |
|
| 181 | + /** |
|
| 182 | + * Get the session cookie, if set. Otherwise return false. |
|
| 183 | + * |
|
| 184 | + * Session cookies without a customer ID are invalid. |
|
| 185 | + * |
|
| 186 | + * @return bool|array |
|
| 187 | + */ |
|
| 188 | + public function get_session_cookie() { |
|
| 189 | + $cookie_value = isset( $_COOKIE[ $this->_cookie ] ) ? wp_unslash( $_COOKIE[ $this->_cookie ] ) : false; // @codingStandardsIgnoreLine. |
|
| 190 | + |
|
| 191 | + if ( empty( $cookie_value ) || ! is_string( $cookie_value ) ) { |
|
| 192 | + return false; |
|
| 193 | + } |
|
| 194 | + |
|
| 195 | + list( $customer_id, $session_expiration, $session_expiring, $cookie_hash ) = explode( '||', $cookie_value ); |
|
| 196 | + |
|
| 197 | + if ( empty( $customer_id ) ) { |
|
| 198 | + return false; |
|
| 199 | + } |
|
| 200 | + |
|
| 201 | + // Validate hash. |
|
| 202 | + $to_hash = $customer_id . '|' . $session_expiration; |
|
| 203 | + $hash = hash_hmac( 'md5', $to_hash, wp_hash( $to_hash ) ); |
|
| 204 | + |
|
| 205 | + if ( empty( $cookie_hash ) || ! hash_equals( $hash, $cookie_hash ) ) { |
|
| 206 | + return false; |
|
| 207 | + } |
|
| 208 | + |
|
| 209 | + return array( $customer_id, $session_expiration, $session_expiring, $cookie_hash ); |
|
| 210 | + } |
|
| 211 | + |
|
| 212 | + /** |
|
| 213 | + * Get session data. |
|
| 214 | + * |
|
| 215 | + * @return array |
|
| 216 | + */ |
|
| 217 | + public function get_session_data() { |
|
| 218 | + return $this->has_session() ? (array) $this->get_session( $this->_customer_id ) : array(); |
|
| 219 | + } |
|
| 220 | + |
|
| 221 | + public function generate_key($customer_id){ |
|
| 222 | 222 | if(!$customer_id){ |
| 223 | 223 | return; |
| 224 | 224 | } |
@@ -226,62 +226,62 @@ discard block |
||
| 226 | 226 | return 'wpi_trans_'.$customer_id; |
| 227 | 227 | } |
| 228 | 228 | |
| 229 | - /** |
|
| 230 | - * Save data. |
|
| 231 | - */ |
|
| 232 | - public function save_data() { |
|
| 233 | - // Dirty if something changed - prevents saving nothing new. |
|
| 234 | - if ( $this->_dirty && $this->has_session() ) { |
|
| 229 | + /** |
|
| 230 | + * Save data. |
|
| 231 | + */ |
|
| 232 | + public function save_data() { |
|
| 233 | + // Dirty if something changed - prevents saving nothing new. |
|
| 234 | + if ( $this->_dirty && $this->has_session() ) { |
|
| 235 | 235 | |
| 236 | 236 | set_transient( $this->generate_key($this->_customer_id), $this->_data, $this->_session_expiration); |
| 237 | 237 | |
| 238 | - $this->_dirty = false; |
|
| 239 | - } |
|
| 240 | - } |
|
| 241 | - |
|
| 242 | - /** |
|
| 243 | - * Destroy all session data. |
|
| 244 | - */ |
|
| 245 | - public function destroy_session() { |
|
| 246 | - $this->delete_session( $this->_customer_id ); |
|
| 247 | - $this->forget_session(); |
|
| 248 | - } |
|
| 249 | - |
|
| 250 | - /** |
|
| 251 | - * Forget all session data without destroying it. |
|
| 252 | - */ |
|
| 253 | - public function forget_session() { |
|
| 254 | - $this->setcookie( $this->_cookie, '', time() - YEAR_IN_SECONDS, $this->use_secure_cookie(), true ); |
|
| 255 | - |
|
| 256 | - wpinv_empty_cart(); |
|
| 257 | - |
|
| 258 | - $this->_data = array(); |
|
| 259 | - $this->_dirty = false; |
|
| 260 | - $this->_customer_id = $this->generate_customer_id(); |
|
| 261 | - } |
|
| 262 | - |
|
| 263 | - /** |
|
| 264 | - * When a user is logged out, ensure they have a unique nonce by using the customer/session ID. |
|
| 265 | - * |
|
| 266 | - * @param int $uid User ID. |
|
| 267 | - * @return string |
|
| 268 | - */ |
|
| 269 | - public function nonce_user_logged_out( $uid ) { |
|
| 270 | - return $this->has_session() && $this->_customer_id ? $this->_customer_id : $uid; |
|
| 271 | - } |
|
| 272 | - |
|
| 273 | - /** |
|
| 274 | - * Returns the session. |
|
| 275 | - * |
|
| 276 | - * @param string $customer_id Customer ID. |
|
| 277 | - * @param mixed $default Default session value. |
|
| 278 | - * @return string|array |
|
| 279 | - */ |
|
| 280 | - public function get_session( $customer_id, $default = false ) { |
|
| 281 | - |
|
| 282 | - if ( defined( 'WP_SETUP_CONFIG' ) ) { |
|
| 283 | - return array(); |
|
| 284 | - } |
|
| 238 | + $this->_dirty = false; |
|
| 239 | + } |
|
| 240 | + } |
|
| 241 | + |
|
| 242 | + /** |
|
| 243 | + * Destroy all session data. |
|
| 244 | + */ |
|
| 245 | + public function destroy_session() { |
|
| 246 | + $this->delete_session( $this->_customer_id ); |
|
| 247 | + $this->forget_session(); |
|
| 248 | + } |
|
| 249 | + |
|
| 250 | + /** |
|
| 251 | + * Forget all session data without destroying it. |
|
| 252 | + */ |
|
| 253 | + public function forget_session() { |
|
| 254 | + $this->setcookie( $this->_cookie, '', time() - YEAR_IN_SECONDS, $this->use_secure_cookie(), true ); |
|
| 255 | + |
|
| 256 | + wpinv_empty_cart(); |
|
| 257 | + |
|
| 258 | + $this->_data = array(); |
|
| 259 | + $this->_dirty = false; |
|
| 260 | + $this->_customer_id = $this->generate_customer_id(); |
|
| 261 | + } |
|
| 262 | + |
|
| 263 | + /** |
|
| 264 | + * When a user is logged out, ensure they have a unique nonce by using the customer/session ID. |
|
| 265 | + * |
|
| 266 | + * @param int $uid User ID. |
|
| 267 | + * @return string |
|
| 268 | + */ |
|
| 269 | + public function nonce_user_logged_out( $uid ) { |
|
| 270 | + return $this->has_session() && $this->_customer_id ? $this->_customer_id : $uid; |
|
| 271 | + } |
|
| 272 | + |
|
| 273 | + /** |
|
| 274 | + * Returns the session. |
|
| 275 | + * |
|
| 276 | + * @param string $customer_id Customer ID. |
|
| 277 | + * @param mixed $default Default session value. |
|
| 278 | + * @return string|array |
|
| 279 | + */ |
|
| 280 | + public function get_session( $customer_id, $default = false ) { |
|
| 281 | + |
|
| 282 | + if ( defined( 'WP_SETUP_CONFIG' ) ) { |
|
| 283 | + return array(); |
|
| 284 | + } |
|
| 285 | 285 | |
| 286 | 286 | if ( !is_user_logged_in() ) { |
| 287 | 287 | if(!wp_verify_nonce( $customer_id, 'wpinv-session-customer-id' )){ |
@@ -296,32 +296,32 @@ discard block |
||
| 296 | 296 | $value = $default; |
| 297 | 297 | } |
| 298 | 298 | |
| 299 | - return maybe_unserialize( $value ); |
|
| 300 | - } |
|
| 299 | + return maybe_unserialize( $value ); |
|
| 300 | + } |
|
| 301 | 301 | |
| 302 | - /** |
|
| 303 | - * Delete the session from the cache and database. |
|
| 304 | - * |
|
| 305 | - * @param int $customer_id Customer ID. |
|
| 306 | - */ |
|
| 307 | - public function delete_session( $customer_id ) { |
|
| 302 | + /** |
|
| 303 | + * Delete the session from the cache and database. |
|
| 304 | + * |
|
| 305 | + * @param int $customer_id Customer ID. |
|
| 306 | + */ |
|
| 307 | + public function delete_session( $customer_id ) { |
|
| 308 | 308 | |
| 309 | 309 | $key = $this->generate_key($customer_id); |
| 310 | 310 | |
| 311 | - delete_transient($key); |
|
| 312 | - } |
|
| 311 | + delete_transient($key); |
|
| 312 | + } |
|
| 313 | 313 | |
| 314 | - /** |
|
| 315 | - * Update the session expiry timestamp. |
|
| 316 | - * |
|
| 317 | - * @param string $customer_id Customer ID. |
|
| 318 | - * @param int $timestamp Timestamp to expire the cookie. |
|
| 319 | - */ |
|
| 320 | - public function update_session_timestamp( $customer_id, $timestamp ) { |
|
| 314 | + /** |
|
| 315 | + * Update the session expiry timestamp. |
|
| 316 | + * |
|
| 317 | + * @param string $customer_id Customer ID. |
|
| 318 | + * @param int $timestamp Timestamp to expire the cookie. |
|
| 319 | + */ |
|
| 320 | + public function update_session_timestamp( $customer_id, $timestamp ) { |
|
| 321 | 321 | |
| 322 | 322 | set_transient( $this->generate_key($customer_id), maybe_serialize( $this->_data ), $timestamp); |
| 323 | 323 | |
| 324 | - } |
|
| 324 | + } |
|
| 325 | 325 | } |
| 326 | 326 | |
| 327 | 327 | global $wpi_session; |
@@ -5,7 +5,7 @@ discard block |
||
| 5 | 5 | * |
| 6 | 6 | */ |
| 7 | 7 | |
| 8 | -defined( 'ABSPATH' ) || exit; |
|
| 8 | +defined('ABSPATH') || exit; |
|
| 9 | 9 | |
| 10 | 10 | /** |
| 11 | 11 | * Session handler class. |
@@ -52,11 +52,11 @@ discard block |
||
| 52 | 52 | */ |
| 53 | 53 | public function __construct() { |
| 54 | 54 | |
| 55 | - $this->_cookie = apply_filters( 'wpinv_cookie', 'wpinv_session_' . COOKIEHASH ); |
|
| 56 | - add_action( 'init', array( $this, 'init' ), -1 ); |
|
| 57 | - add_action( 'wp_logout', array( $this, 'destroy_session' ) ); |
|
| 58 | - add_action( 'wp', array( $this, 'set_customer_session_cookie' ), 10 ); |
|
| 59 | - add_action( 'shutdown', array( $this, 'save_data' ), 20 ); |
|
| 55 | + $this->_cookie = apply_filters('wpinv_cookie', 'wpinv_session_' . COOKIEHASH); |
|
| 56 | + add_action('init', array($this, 'init'), -1); |
|
| 57 | + add_action('wp_logout', array($this, 'destroy_session')); |
|
| 58 | + add_action('wp', array($this, 'set_customer_session_cookie'), 10); |
|
| 59 | + add_action('shutdown', array($this, 'save_data'), 20); |
|
| 60 | 60 | |
| 61 | 61 | } |
| 62 | 62 | |
@@ -68,8 +68,8 @@ discard block |
||
| 68 | 68 | public function init() { |
| 69 | 69 | $this->init_session_cookie(); |
| 70 | 70 | |
| 71 | - if ( ! is_user_logged_in() ) { |
|
| 72 | - add_filter( 'nonce_user_logged_out', array( $this, 'nonce_user_logged_out' ) ); |
|
| 71 | + if (!is_user_logged_in()) { |
|
| 72 | + add_filter('nonce_user_logged_out', array($this, 'nonce_user_logged_out')); |
|
| 73 | 73 | } |
| 74 | 74 | } |
| 75 | 75 | |
@@ -81,7 +81,7 @@ discard block |
||
| 81 | 81 | public function init_session_cookie() { |
| 82 | 82 | $cookie = $this->get_session_cookie(); |
| 83 | 83 | |
| 84 | - if ( $cookie ) { |
|
| 84 | + if ($cookie) { |
|
| 85 | 85 | $this->_customer_id = $cookie[0]; |
| 86 | 86 | $this->_session_expiration = $cookie[1]; |
| 87 | 87 | $this->_session_expiring = $cookie[2]; |
@@ -89,17 +89,17 @@ discard block |
||
| 89 | 89 | $this->_data = $this->get_session_data(); |
| 90 | 90 | |
| 91 | 91 | // If the user logs in, update session. |
| 92 | - if ( is_user_logged_in() && get_current_user_id() != $this->_customer_id ) { |
|
| 92 | + if (is_user_logged_in() && get_current_user_id() != $this->_customer_id) { |
|
| 93 | 93 | $this->_customer_id = get_current_user_id(); |
| 94 | 94 | $this->_dirty = true; |
| 95 | 95 | $this->save_data(); |
| 96 | - $this->set_customer_session_cookie( true ); |
|
| 96 | + $this->set_customer_session_cookie(true); |
|
| 97 | 97 | } |
| 98 | 98 | |
| 99 | 99 | // Update session if its close to expiring. |
| 100 | - if ( time() > $this->_session_expiring ) { |
|
| 100 | + if (time() > $this->_session_expiring) { |
|
| 101 | 101 | $this->set_session_expiration(); |
| 102 | - $this->update_session_timestamp( $this->_customer_id, $this->_session_expiration ); |
|
| 102 | + $this->update_session_timestamp($this->_customer_id, $this->_session_expiration); |
|
| 103 | 103 | } |
| 104 | 104 | } else { |
| 105 | 105 | $this->set_session_expiration(); |
@@ -117,25 +117,25 @@ discard block |
||
| 117 | 117 | * |
| 118 | 118 | * @param bool $set Should the session cookie be set. |
| 119 | 119 | */ |
| 120 | - public function set_customer_session_cookie( $set ) { |
|
| 121 | - if ( $set ) { |
|
| 120 | + public function set_customer_session_cookie($set) { |
|
| 121 | + if ($set) { |
|
| 122 | 122 | $to_hash = $this->_customer_id . '|' . $this->_session_expiration; |
| 123 | - $cookie_hash = hash_hmac( 'md5', $to_hash, wp_hash( $to_hash ) ); |
|
| 123 | + $cookie_hash = hash_hmac('md5', $to_hash, wp_hash($to_hash)); |
|
| 124 | 124 | $cookie_value = $this->_customer_id . '||' . $this->_session_expiration . '||' . $this->_session_expiring . '||' . $cookie_hash; |
| 125 | 125 | $this->_has_cookie = true; |
| 126 | 126 | |
| 127 | - if ( ! isset( $_COOKIE[ $this->_cookie ] ) || $_COOKIE[ $this->_cookie ] !== $cookie_value ) { |
|
| 128 | - $this->setcookie( $this->_cookie, $cookie_value, $this->_session_expiration, $this->use_secure_cookie(), true ); |
|
| 127 | + if (!isset($_COOKIE[$this->_cookie]) || $_COOKIE[$this->_cookie] !== $cookie_value) { |
|
| 128 | + $this->setcookie($this->_cookie, $cookie_value, $this->_session_expiration, $this->use_secure_cookie(), true); |
|
| 129 | 129 | } |
| 130 | 130 | } |
| 131 | 131 | } |
| 132 | 132 | |
| 133 | - public function setcookie($name, $value, $expire = 0, $secure = false, $httponly = false){ |
|
| 134 | - if ( ! headers_sent() ) { |
|
| 135 | - setcookie( $name, $value, $expire, COOKIEPATH ? COOKIEPATH : '/', COOKIE_DOMAIN, $secure, apply_filters( 'wpinv_cookie_httponly', $httponly, $name, $value, $expire, $secure ) ); |
|
| 136 | - } elseif ( defined( 'WP_DEBUG' ) && WP_DEBUG ) { |
|
| 137 | - headers_sent( $file, $line ); |
|
| 138 | - trigger_error( "{$name} cookie cannot be set - headers already sent by {$file} on line {$line}", E_USER_NOTICE ); // @codingStandardsIgnoreLine |
|
| 133 | + public function setcookie($name, $value, $expire = 0, $secure = false, $httponly = false) { |
|
| 134 | + if (!headers_sent()) { |
|
| 135 | + setcookie($name, $value, $expire, COOKIEPATH ? COOKIEPATH : '/', COOKIE_DOMAIN, $secure, apply_filters('wpinv_cookie_httponly', $httponly, $name, $value, $expire, $secure)); |
|
| 136 | + } elseif (defined('WP_DEBUG') && WP_DEBUG) { |
|
| 137 | + headers_sent($file, $line); |
|
| 138 | + trigger_error("{$name} cookie cannot be set - headers already sent by {$file} on line {$line}", E_USER_NOTICE); // @codingStandardsIgnoreLine |
|
| 139 | 139 | } |
| 140 | 140 | } |
| 141 | 141 | |
@@ -146,8 +146,8 @@ discard block |
||
| 146 | 146 | * @return bool |
| 147 | 147 | */ |
| 148 | 148 | protected function use_secure_cookie() { |
| 149 | - $is_https = false !== strstr( get_option( 'home' ), 'https:' ); |
|
| 150 | - return apply_filters( 'wpinv_session_use_secure_cookie', $is_https && is_ssl() ); |
|
| 149 | + $is_https = false !== strstr(get_option('home'), 'https:'); |
|
| 150 | + return apply_filters('wpinv_session_use_secure_cookie', $is_https && is_ssl()); |
|
| 151 | 151 | } |
| 152 | 152 | |
| 153 | 153 | /** |
@@ -156,15 +156,15 @@ discard block |
||
| 156 | 156 | * @return bool |
| 157 | 157 | */ |
| 158 | 158 | public function has_session() { |
| 159 | - return isset( $_COOKIE[ $this->_cookie ] ) || $this->_has_cookie || is_user_logged_in(); // @codingStandardsIgnoreLine. |
|
| 159 | + return isset($_COOKIE[$this->_cookie]) || $this->_has_cookie || is_user_logged_in(); // @codingStandardsIgnoreLine. |
|
| 160 | 160 | } |
| 161 | 161 | |
| 162 | 162 | /** |
| 163 | 163 | * Set session expiration. |
| 164 | 164 | */ |
| 165 | 165 | public function set_session_expiration() { |
| 166 | - $this->_session_expiring = time() + intval( apply_filters( 'wpinv_session_expiring', 60 * 60 * 47 ) ); // 47 Hours. |
|
| 167 | - $this->_session_expiration = time() + intval( apply_filters( 'wpinv_session_expiration', 60 * 60 * 48 ) ); // 48 Hours. |
|
| 166 | + $this->_session_expiring = time() + intval(apply_filters('wpinv_session_expiring', 60 * 60 * 47)); // 47 Hours. |
|
| 167 | + $this->_session_expiration = time() + intval(apply_filters('wpinv_session_expiration', 60 * 60 * 48)); // 48 Hours. |
|
| 168 | 168 | } |
| 169 | 169 | |
| 170 | 170 | /** |
@@ -174,8 +174,8 @@ discard block |
||
| 174 | 174 | */ |
| 175 | 175 | public function generate_customer_id() { |
| 176 | 176 | require_once ABSPATH . 'wp-includes/class-phpass.php'; |
| 177 | - $hasher = new PasswordHash( 8, false ); |
|
| 178 | - return md5( $hasher->get_random_bytes( 32 ) ); |
|
| 177 | + $hasher = new PasswordHash(8, false); |
|
| 178 | + return md5($hasher->get_random_bytes(32)); |
|
| 179 | 179 | } |
| 180 | 180 | |
| 181 | 181 | /** |
@@ -186,27 +186,27 @@ discard block |
||
| 186 | 186 | * @return bool|array |
| 187 | 187 | */ |
| 188 | 188 | public function get_session_cookie() { |
| 189 | - $cookie_value = isset( $_COOKIE[ $this->_cookie ] ) ? wp_unslash( $_COOKIE[ $this->_cookie ] ) : false; // @codingStandardsIgnoreLine. |
|
| 189 | + $cookie_value = isset($_COOKIE[$this->_cookie]) ? wp_unslash($_COOKIE[$this->_cookie]) : false; // @codingStandardsIgnoreLine. |
|
| 190 | 190 | |
| 191 | - if ( empty( $cookie_value ) || ! is_string( $cookie_value ) ) { |
|
| 191 | + if (empty($cookie_value) || !is_string($cookie_value)) { |
|
| 192 | 192 | return false; |
| 193 | 193 | } |
| 194 | 194 | |
| 195 | - list( $customer_id, $session_expiration, $session_expiring, $cookie_hash ) = explode( '||', $cookie_value ); |
|
| 195 | + list($customer_id, $session_expiration, $session_expiring, $cookie_hash) = explode('||', $cookie_value); |
|
| 196 | 196 | |
| 197 | - if ( empty( $customer_id ) ) { |
|
| 197 | + if (empty($customer_id)) { |
|
| 198 | 198 | return false; |
| 199 | 199 | } |
| 200 | 200 | |
| 201 | 201 | // Validate hash. |
| 202 | 202 | $to_hash = $customer_id . '|' . $session_expiration; |
| 203 | - $hash = hash_hmac( 'md5', $to_hash, wp_hash( $to_hash ) ); |
|
| 203 | + $hash = hash_hmac('md5', $to_hash, wp_hash($to_hash)); |
|
| 204 | 204 | |
| 205 | - if ( empty( $cookie_hash ) || ! hash_equals( $hash, $cookie_hash ) ) { |
|
| 205 | + if (empty($cookie_hash) || !hash_equals($hash, $cookie_hash)) { |
|
| 206 | 206 | return false; |
| 207 | 207 | } |
| 208 | 208 | |
| 209 | - return array( $customer_id, $session_expiration, $session_expiring, $cookie_hash ); |
|
| 209 | + return array($customer_id, $session_expiration, $session_expiring, $cookie_hash); |
|
| 210 | 210 | } |
| 211 | 211 | |
| 212 | 212 | /** |
@@ -215,15 +215,15 @@ discard block |
||
| 215 | 215 | * @return array |
| 216 | 216 | */ |
| 217 | 217 | public function get_session_data() { |
| 218 | - return $this->has_session() ? (array) $this->get_session( $this->_customer_id ) : array(); |
|
| 218 | + return $this->has_session() ? (array) $this->get_session($this->_customer_id) : array(); |
|
| 219 | 219 | } |
| 220 | 220 | |
| 221 | - public function generate_key($customer_id){ |
|
| 222 | - if(!$customer_id){ |
|
| 221 | + public function generate_key($customer_id) { |
|
| 222 | + if (!$customer_id) { |
|
| 223 | 223 | return; |
| 224 | 224 | } |
| 225 | 225 | |
| 226 | - return 'wpi_trans_'.$customer_id; |
|
| 226 | + return 'wpi_trans_' . $customer_id; |
|
| 227 | 227 | } |
| 228 | 228 | |
| 229 | 229 | /** |
@@ -231,9 +231,9 @@ discard block |
||
| 231 | 231 | */ |
| 232 | 232 | public function save_data() { |
| 233 | 233 | // Dirty if something changed - prevents saving nothing new. |
| 234 | - if ( $this->_dirty && $this->has_session() ) { |
|
| 234 | + if ($this->_dirty && $this->has_session()) { |
|
| 235 | 235 | |
| 236 | - set_transient( $this->generate_key($this->_customer_id), $this->_data, $this->_session_expiration); |
|
| 236 | + set_transient($this->generate_key($this->_customer_id), $this->_data, $this->_session_expiration); |
|
| 237 | 237 | |
| 238 | 238 | $this->_dirty = false; |
| 239 | 239 | } |
@@ -243,7 +243,7 @@ discard block |
||
| 243 | 243 | * Destroy all session data. |
| 244 | 244 | */ |
| 245 | 245 | public function destroy_session() { |
| 246 | - $this->delete_session( $this->_customer_id ); |
|
| 246 | + $this->delete_session($this->_customer_id); |
|
| 247 | 247 | $this->forget_session(); |
| 248 | 248 | } |
| 249 | 249 | |
@@ -251,7 +251,7 @@ discard block |
||
| 251 | 251 | * Forget all session data without destroying it. |
| 252 | 252 | */ |
| 253 | 253 | public function forget_session() { |
| 254 | - $this->setcookie( $this->_cookie, '', time() - YEAR_IN_SECONDS, $this->use_secure_cookie(), true ); |
|
| 254 | + $this->setcookie($this->_cookie, '', time() - YEAR_IN_SECONDS, $this->use_secure_cookie(), true); |
|
| 255 | 255 | |
| 256 | 256 | wpinv_empty_cart(); |
| 257 | 257 | |
@@ -266,7 +266,7 @@ discard block |
||
| 266 | 266 | * @param int $uid User ID. |
| 267 | 267 | * @return string |
| 268 | 268 | */ |
| 269 | - public function nonce_user_logged_out( $uid ) { |
|
| 269 | + public function nonce_user_logged_out($uid) { |
|
| 270 | 270 | return $this->has_session() && $this->_customer_id ? $this->_customer_id : $uid; |
| 271 | 271 | } |
| 272 | 272 | |
@@ -277,14 +277,14 @@ discard block |
||
| 277 | 277 | * @param mixed $default Default session value. |
| 278 | 278 | * @return string|array |
| 279 | 279 | */ |
| 280 | - public function get_session( $customer_id, $default = false ) { |
|
| 280 | + public function get_session($customer_id, $default = false) { |
|
| 281 | 281 | |
| 282 | - if ( defined( 'WP_SETUP_CONFIG' ) ) { |
|
| 282 | + if (defined('WP_SETUP_CONFIG')) { |
|
| 283 | 283 | return array(); |
| 284 | 284 | } |
| 285 | 285 | |
| 286 | - if ( !is_user_logged_in() ) { |
|
| 287 | - if(!wp_verify_nonce( $customer_id, 'wpinv-session-customer-id' )){ |
|
| 286 | + if (!is_user_logged_in()) { |
|
| 287 | + if (!wp_verify_nonce($customer_id, 'wpinv-session-customer-id')) { |
|
| 288 | 288 | return array(); |
| 289 | 289 | } |
| 290 | 290 | } |
@@ -292,11 +292,11 @@ discard block |
||
| 292 | 292 | $key = $this->generate_key($customer_id); |
| 293 | 293 | $value = get_transient($key); |
| 294 | 294 | |
| 295 | - if ( !$value ) { |
|
| 295 | + if (!$value) { |
|
| 296 | 296 | $value = $default; |
| 297 | 297 | } |
| 298 | 298 | |
| 299 | - return maybe_unserialize( $value ); |
|
| 299 | + return maybe_unserialize($value); |
|
| 300 | 300 | } |
| 301 | 301 | |
| 302 | 302 | /** |
@@ -304,7 +304,7 @@ discard block |
||
| 304 | 304 | * |
| 305 | 305 | * @param int $customer_id Customer ID. |
| 306 | 306 | */ |
| 307 | - public function delete_session( $customer_id ) { |
|
| 307 | + public function delete_session($customer_id) { |
|
| 308 | 308 | |
| 309 | 309 | $key = $this->generate_key($customer_id); |
| 310 | 310 | |
@@ -317,9 +317,9 @@ discard block |
||
| 317 | 317 | * @param string $customer_id Customer ID. |
| 318 | 318 | * @param int $timestamp Timestamp to expire the cookie. |
| 319 | 319 | */ |
| 320 | - public function update_session_timestamp( $customer_id, $timestamp ) { |
|
| 320 | + public function update_session_timestamp($customer_id, $timestamp) { |
|
| 321 | 321 | |
| 322 | - set_transient( $this->generate_key($customer_id), maybe_serialize( $this->_data ), $timestamp); |
|
| 322 | + set_transient($this->generate_key($customer_id), maybe_serialize($this->_data), $timestamp); |
|
| 323 | 323 | |
| 324 | 324 | } |
| 325 | 325 | } |