if (!defined('ABSPATH')) : define('DOING_AJAX', true); $root = dirname(dirname(dirname(dirname(dirname(dirname(__FILE__)))))); require_once( $root.'/wp-load.php' ); endif; if (sizeof(jigoshop_cart::$cart_contents)==0) : echo '<p class="error">'.__('Sorry, your session has expired.', 'jigoshop').' <a href="'.home_url().'">'.__('Return to homepage →', 'jigoshop').'</a></p>'; exit; endif; if (isset($_POST['shipping_method'])) $_SESSION['_chosen_method_id'] = $_POST['shipping_method']; if (isset($_POST['country'])) jigoshop_customer::set_country( $_POST['country'] ); if (isset($_POST['state'])) jigoshop_customer::set_state( $_POST['state'] ); if (isset($_POST['postcode'])) jigoshop_customer::set_postcode( $_POST['postcode'] ); if (isset($_POST['s_country'])) jigoshop_customer::set_shipping_country( $_POST['s_country'] ); if (isset($_POST['s_state'])) jigoshop_customer::set_shipping_state( $_POST['s_state'] ); if (isset($_POST['s_postcode'])) jigoshop_customer::set_shipping_postcode( $_POST['s_postcode'] ); jigoshop_cart::calculate_totals(); ?> <div id="order_review"> <table class="shop_table"> <thead> <tr> <th><?php _e('Product', 'jigoshop'); ?></th> <th><?php _e('Qty', 'jigoshop'); ?></th>
function jigoshop_pay_action() { if (!is_jigoshop_single_page(JIGOSHOP_PAY)) { return; } if (isset($_GET['pay_for_order']) && isset($_GET['order']) && isset($_GET['order_id'])) { // Pay for existing order $order_key = urldecode($_GET['order']); $order_id = (int) $_GET['order_id']; $order = new jigoshop_order($order_id); if ($order->id == $order_id && $order->order_key == $order_key && $order->status == 'pending') { // Set customer location to order location if ($order->billing_country) { jigoshop_customer::set_country($order->billing_country); } if ($order->billing_state) { jigoshop_customer::set_state($order->billing_state); } if ($order->billing_postcode) { jigoshop_customer::set_postcode($order->billing_postcode); } // Pay form was posted - process payment if (isset($_POST['pay']) && jigoshop::verify_nonce('pay')) { // Update payment method if ($order->order_total > 0) { $payment_method = jigowatt_clean($_POST['payment_method']); $data = (array) maybe_unserialize(get_post_meta($order_id, 'order_data', true)); $data['payment_method'] = $payment_method; update_post_meta($order_id, 'order_data', $data); $available_gateways = jigoshop_payment_gateways::get_available_payment_gateways(); $result = $available_gateways[$payment_method]->process_payment($order_id); // Redirect to success/confirmation/payment page if ($result['result'] == 'success') { wp_safe_redirect($result['redirect']); exit; } } else { // No payment was required for order $order->payment_complete(); // filter redirect page $checkout_redirect = apply_filters('jigoshop_get_checkout_redirect_page_id', jigoshop_get_page_id('thanks')); wp_safe_redirect(get_permalink($checkout_redirect)); exit; } } } elseif ($order->status != 'pending') { jigoshop::add_error(__('Your order has already been paid for. Please contact us if you need assistance.', 'jigoshop')); } else { jigoshop::add_error(__('Invalid order.', 'jigoshop')); } } else { // Pay for order after checkout step if (isset($_GET['order'])) { $order_id = $_GET['order']; } else { $order_id = 0; } if (isset($_GET['key'])) { $order_key = $_GET['key']; } else { $order_key = ''; } if ($order_id > 0) { $order = new jigoshop_order($order_id); if ($order->order_key != $order_key || $order->status != 'pending') { wp_safe_redirect(apply_filters('jigoshop_get_myaccount_page_id', get_permalink(jigoshop_get_page_id('myaccount')))); exit; } } else { wp_safe_redirect(apply_filters('jigoshop_get_myaccount_page_id', get_permalink(jigoshop_get_page_id('myaccount')))); exit; } } }
/** * Process the checkout after the confirm order button is pressed */ public function process_checkout() { if (!defined('JIGOSHOP_CHECKOUT')) { define('JIGOSHOP_CHECKOUT', true); } // Initialize cart jigoshop_cart::get_cart(); jigoshop_cart::calculate_totals(); if (isset($_POST) && $_POST && !isset($_POST['login'])) { jigoshop::verify_nonce('process_checkout'); // this will fill in our $posted array with validated data self::validate_checkout(); $gateway = jigoshop_payment_gateways::get_gateway($this->posted['payment_method']); if (self::process_gateway($gateway)) { $gateway->validate_fields(); } do_action('jigoshop_after_checkout_validation', $this->posted, $_POST, sizeof(jigoshop::$errors)); if (jigoshop::has_errors()) { return false; } if (!isset($_POST['update_totals'])) { $user_id = get_current_user_id(); // Create customer account and log them in if ($this->show_signup && !$user_id && $this->posted['create_account']) { $user_id = $this->create_user_account(); if ($user_id === 0) { return false; } } $billing = array('first_name' => $this->posted['billing_first_name'], 'last_name' => $this->posted['billing_last_name'], 'company' => $this->posted['billing_company'], 'address_1' => $this->posted['billing_address_1'], 'address_2' => $this->posted['billing_address_2'], 'city' => $this->posted['billing_city'], 'state' => $this->posted['billing_state'], 'postcode' => $this->posted['billing_postcode'], 'country' => $this->posted['billing_country'], 'phone' => $this->posted['billing_phone'], 'email' => $this->posted['billing_email']); jigoshop_customer::set_country($billing['country']); jigoshop_customer::set_state($billing['state']); jigoshop_customer::set_postcode($billing['postcode']); if (isset($this->posted['billing_euvatno']) && $this->valid_euvatno) { $billing['euvatno'] = $this->posted['billing_euvatno']; $billing['euvatno'] = str_replace(' ', '', $billing['euvatno']); // If country code is not provided - add one. if (strpos($billing['euvatno'], $billing['country']) === false) { $billing['euvatno'] = $billing['country'] . $billing['euvatno']; } } // Get shipping/billing if (!empty($this->posted['shiptobilling'])) { $shipping = $billing; unset($shipping['phone'], $shipping['email']); } elseif (jigoshop_shipping::is_enabled()) { $shipping = array('first_name' => $this->posted['shipping_first_name'], 'last_name' => $this->posted['shipping_last_name'], 'company' => $this->posted['shipping_company'], 'address_1' => $this->posted['shipping_address_1'], 'address_2' => $this->posted['shipping_address_2'], 'city' => $this->posted['shipping_city'], 'state' => $this->posted['shipping_state'], 'postcode' => $this->posted['shipping_postcode'], 'country' => $this->posted['shipping_country']); } jigoshop_customer::set_shipping_country($shipping['country']); jigoshop_customer::set_shipping_state($shipping['state']); jigoshop_customer::set_shipping_postcode($shipping['postcode']); // Update totals based on processed customer address jigoshop_cart::calculate_totals(); // Save billing/shipping to user meta fields if ($user_id > 0) { foreach ($billing as $field => $value) { update_user_meta($user_id, 'billing_' . $field, $value); } if (isset($shipping)) { foreach ($shipping as $field => $value) { update_user_meta($user_id, 'shipping_' . $field, $value); } } } if (!isset($_POST['submit_action']) || $_POST['submit_action'] != 'place_order') { $result = jigoshop::redirect(jigoshop_get_page_id(JIGOSHOP_CHECKOUT)); return array('result' => 'redirect', 'redirect' => $result); } // Order meta data $data = array(); $applied_coupons = array_map(function ($coupon) { return JS_Coupons::get_coupon($coupon); }, jigoshop_cart::get_coupons()); do_action('jigoshop_checkout_update_order_total', $this->posted); foreach ($billing as $field => $value) { $data['billing_' . $field] = $value; } if (isset($shipping)) { foreach ($shipping as $field => $value) { $data['shipping_' . $field] = $value; } } $data['order_discount_coupons'] = $applied_coupons; $data['shipping_method'] = $this->posted['shipping_method']; $data['shipping_service'] = $this->posted['shipping_service']; $data['payment_method'] = $this->posted['payment_method']; $data['payment_method_title'] = $gateway->title; $data['order_subtotal'] = jigoshop_cart::get_subtotal(); $data['order_discount_subtotal'] = jigoshop_cart::get_discount_subtotal(); $data['order_shipping'] = jigoshop_cart::get_shipping_total(); $data['order_discount'] = jigoshop_cart::get_total_discount(false); $data['order_tax'] = jigoshop_cart::get_taxes_as_string(); $data['order_tax_no_shipping_tax'] = jigoshop_cart::get_total_cart_tax_without_shipping_tax(); $data['order_tax_divisor'] = jigoshop_cart::get_tax_divisor(); $data['order_shipping_tax'] = jigoshop_cart::get_shipping_tax(); $data['order_total'] = jigoshop_cart::get_total(false); $data['order_total_prices_per_tax_class_ex_tax'] = jigoshop_cart::get_price_per_tax_class_ex_tax(); if ($this->valid_euvatno) { $data['order_tax'] = ''; $temp = jigoshop_cart::get_total_cart_tax_without_shipping_tax(); $data['order_total'] -= $data['order_shipping_tax'] + $temp; $data['order_shipping_tax'] = 0; } // Cart items $order_items = array(); foreach (jigoshop_cart::get_cart() as $values) { /** @var jigoshop_product $product */ $product = $values['data']; // Check stock levels if (!$product->has_enough_stock($values['quantity'])) { jigoshop::add_error(sprintf(__('Sorry, we do not have enough "%s" in stock to fulfill your order. Please edit your cart and try again. We apologize for any inconvenience caused.', 'jigoshop'), $product->get_title())); if (self::get_options()->get('jigoshop_show_stock') == 'yes') { jigoshop::add_error(sprintf(__('We have only %d available at this time.', 'jigoshop'), $product->get_stock())); } break; } // Calc item tax to store $rates = $product->get_tax_destination_rate(); $rates = current($rates); if (isset($rates['rate'])) { $rate = $rates['rate']; } else { $rate = 0.0; } if ($this->valid_euvatno) { $rate = 0.0; } $price_inc_tax = $product->get_price_with_tax(); if (!empty($values['variation_id'])) { $product_id = $values['variation_id']; } else { $product_id = $values['product_id']; } $custom_products = (array) jigoshop_session::instance()->customized_products; $custom = isset($custom_products[$product_id]) ? $custom_products[$product_id] : ''; if (!empty($custom)) { unset($custom_products[$product_id]); jigoshop_session::instance()->customized_products = $custom_products; } $order_items[] = apply_filters('new_order_item', array('id' => $values['product_id'], 'variation_id' => $values['variation_id'], 'variation' => $values['variation'], 'customization' => $custom, 'name' => $product->get_title(), 'qty' => (int) $values['quantity'], 'cost' => $product->get_price_excluding_tax(), 'cost_inc_tax' => $price_inc_tax, 'taxrate' => $rate), $values); } if (jigoshop::has_errors()) { return false; } // Insert or update the post data $create_new_order = true; $order_data = array('post_type' => 'shop_order', 'post_title' => 'Order – ' . date('F j, Y @ h:i A'), 'post_status' => 'publish', 'post_excerpt' => $this->posted['order_comments'], 'post_author' => 1); $order_id = 0; if (isset(jigoshop_session::instance()->order_awaiting_payment) && jigoshop_session::instance()->order_awaiting_payment > 0) { $order_id = absint(jigoshop_session::instance()->order_awaiting_payment); $terms = wp_get_object_terms($order_id, 'shop_order_status', array('fields' => 'slugs')); $order_status = isset($terms[0]) ? $terms[0] : 'pending'; // Resume the unpaid order if its pending if ($order_status == 'pending' || $order_status == 'failed') { $create_new_order = false; $order_data['ID'] = $order_id; wp_update_post($order_data); } } if ($create_new_order) { $order_id = wp_insert_post($order_data); } if (is_wp_error($order_id) || $order_id === 0) { jigoshop::add_error(__('Error: Unable to create order. Please try again.', 'jigoshop')); return false; } // Update post meta update_post_meta($order_id, 'order_data', $data); update_post_meta($order_id, 'order_key', uniqid('order_')); update_post_meta($order_id, 'customer_user', (int) $user_id); update_post_meta($order_id, 'order_items', $order_items); wp_set_object_terms($order_id, 'pending', 'shop_order_status'); $order = new jigoshop_order($order_id); /* Coupon usage limit */ foreach ($data['order_discount_coupons'] as $coupon) { $coupon_id = JS_Coupons::get_coupon_post_id($coupon['code']); if ($coupon_id !== false) { $usage_count = get_post_meta($coupon_id, 'usage', true); $usage_count = empty($usage_count) ? 1 : $usage_count + 1; update_post_meta($coupon_id, 'usage', $usage_count); } } if ($create_new_order) { do_action('jigoshop_new_order', $order_id); } else { do_action('jigoshop_resume_order', $order_id); } do_action('jigoshop_checkout_update_order_meta', $order_id, $this->posted); // can't just simply check needs_payment() here, as paypal may have force payment set to true if (self::process_gateway($gateway)) { // Store Order ID in session so it can be re-used after payment failure jigoshop_session::instance()->order_awaiting_payment = $order_id; // Process Payment $result = $gateway->process_payment($order_id); // Redirect to success/confirmation/payment page if ($result['result'] == 'success') { return $result; } return false; } else { // No payment was required for order $order->payment_complete(); // Empty the Cart jigoshop_cart::empty_cart(); // Redirect to success/confirmation/payment page $checkout_redirect = apply_filters('jigoshop_get_checkout_redirect_page_id', jigoshop_get_page_id('thanks')); return array('result' => 'redirect', 'redirect' => $checkout_redirect); } } } return true; }
/** * Outputs the pay page - payment gateways can hook in here to show payment forms etc **/ function jigoshop_pay() { if ( isset($_GET['pay_for_order']) && isset($_GET['order']) && isset($_GET['order_id']) ) : // Pay for existing order $order_key = urldecode( $_GET['order'] ); $order_id = (int) $_GET['order_id']; $order = &new jigoshop_order( $order_id ); if ($order->id == $order_id && $order->order_key == $order_key && $order->status=='pending') : // Set customer location to order location if ($order->billing_country) jigoshop_customer::set_country( $order->billing_country ); if ($order->billing_state) jigoshop_customer::set_state( $order->billing_state ); if ($order->billing_postcode) jigoshop_customer::set_postcode( $order->billing_postcode ); // Pay form was posted - process payment if (isset($_POST['pay']) && jigoshop::verify_nonce('pay')) : // Update payment method if ($order->order_total > 0 ) : $payment_method = jigowatt_clean($_POST['payment_method']); $data = (array) maybe_unserialize( get_post_meta( $order_id, 'order_data', true ) ); $data['payment_method'] = $payment_method; update_post_meta( $order_id, 'order_data', $data ); $available_gateways = jigoshop_payment_gateways::get_available_payment_gateways(); $result = $available_gateways[$payment_method]->process_payment( $order_id ); // Redirect to success/confirmation/payment page if ($result['result']=='success') : wp_safe_redirect( $result['redirect'] ); exit; endif; else : // No payment was required for order $order->payment_complete(); wp_safe_redirect( get_permalink(get_option('jigoshop_thanks_page_id')) ); exit; endif; endif; // Show messages jigoshop::show_messages(); // Show form jigoshop_pay_for_existing_order( $order ); elseif ($order->status!='pending') : jigoshop::add_error( __('Your order has already been paid for. Please contact us if you need assistance.', 'jigoshop') ); jigoshop::show_messages(); else : jigoshop::add_error( __('Invalid order.', 'jigoshop') ); jigoshop::show_messages(); endif; else : // Pay for order after checkout step if (isset($_GET['order'])) $order_id = $_GET['order']; else $order_id = 0; if (isset($_GET['key'])) $order_key = $_GET['key']; else $order_key = ''; if ($order_id > 0) : $order = &new jigoshop_order( $order_id ); if ($order->order_key == $order_key && $order->status=='pending') : ?> <ul class="order_details"> <li class="order"> <?php _e('Order:', 'jigoshop'); ?> <strong># <?php echo $order->id; ?></strong> </li> <li class="date"> <?php _e('Date:', 'jigoshop'); ?> <strong><?php echo date(get_option('date_format'), strtotime($order->order_date)); ?></strong> </li> <li class="total"> <?php _e('Total:', 'jigoshop'); ?> <strong><?php echo jigoshop_price($order->order_total); ?></strong> </li> <li class="method"> <?php _e('Payment method:', 'jigoshop'); ?> <strong><?php $gateways = jigoshop_payment_gateways::payment_gateways(); if (isset($gateways[$order->payment_method])) echo $gateways[$order->payment_method]->title; else echo $order->payment_method; ?></strong> </li> </ul> <?php do_action( 'receipt_' . $order->payment_method, $order_id ); ?> <div class="clear"></div> <?php else : wp_safe_redirect( get_permalink(get_option('jigoshop_myaccount_page_id')) ); exit; endif; else : wp_safe_redirect( get_permalink(get_option('jigoshop_myaccount_page_id')) ); exit; endif; endif; }
function jigoshop_ajax_update_order_review() { check_ajax_referer('update-order-review', 'security'); if (!defined('JIGOSHOP_CHECKOUT')) { define('JIGOSHOP_CHECKOUT', true); } jigoshop_cart::get_cart(); if (sizeof(jigoshop_cart::$cart_contents) == 0) { echo '<p class="error">' . __('Sorry, your session has expired.', 'jigoshop') . ' <a href="' . home_url() . '">' . __('Return to homepage →', 'jigoshop') . '</a></p>'; exit; } do_action('jigoshop_checkout_update_order_review', $_POST['post_data']); if (isset($_POST['shipping_method'])) { $shipping_method = explode(":", $_POST['shipping_method']); jigoshop_session::instance()->chosen_shipping_method_id = $shipping_method[0]; if (is_numeric($shipping_method[2])) { jigoshop_session::instance()->selected_rate_id = $shipping_method[2]; } } if (!empty($_POST['coupon_code'])) { jigoshop_cart::add_discount(sanitize_title($_POST['coupon_code'])); jigoshop::show_messages(); } if (isset($_POST['country'])) { jigoshop_customer::set_country($_POST['country']); } if (isset($_POST['state'])) { jigoshop_customer::set_state($_POST['state']); } if (isset($_POST['postcode'])) { jigoshop_customer::set_postcode($_POST['postcode']); } if (isset($_POST['s_country'])) { jigoshop_customer::set_shipping_country($_POST['s_country']); } if (isset($_POST['s_state'])) { jigoshop_customer::set_shipping_state($_POST['s_state']); } if (isset($_POST['s_postcode'])) { jigoshop_customer::set_shipping_postcode($_POST['s_postcode']); } jigoshop_cart::calculate_totals(); do_action('jigoshop_checkout_order_review'); die; }