/** * Is customer shipping outside base, but within the same country? This is * used to determine how to apply taxes. Also, it no country is set, assume * shipping is going to base country. */ public static function is_customer_outside_base($shippable) { $outside = false; $country = $shippable ? self::get_shipping_country() : self::get_country(); // if no country is set, then assume customer is from the shop base if ($country) { $shop_country = fflcommerce_countries::get_base_country(); // check if it's a country with states. if (fflcommerce_countries::country_has_states($country)) { $shop_state = fflcommerce_countries::get_base_state(); // taxes only apply if the customer is shipping in the same country. If the customer is // shipping outside of the shop country, then taxes do not apply. if ($shop_country === $country && $shop_state !== ($shippable ? self::get_shipping_state() : self::get_state())) { $outside = true; } } else { if (fflcommerce_countries::is_eu_country($shop_country) && $shop_country != $country) { // if both base country and shipping country are in the EU, then outside country base is true $outside = fflcommerce_countries::is_eu_country($country); } } } return $outside; }
public function __construct($id) { $this->id = $id; $meta = get_user_meta($id); if (isset($meta['billing_first_name'])) { $this->billing_first_name = $meta['billing_first_name'][0]; } if (isset($meta['billing_last_name'])) { $this->billing_last_name = $meta['billing_last_name'][0]; } if (isset($meta['billing_company'])) { $this->billing_company = $meta['billing_company'][0]; } if (isset($meta['billing_address_1'])) { $this->billing_address_1 = $meta['billing_address_1'][0]; } if (isset($meta['billing_address_2'])) { $this->billing_address_2 = $meta['billing_address_2'][0]; } if (isset($meta['billing_city'])) { $this->billing_city = $meta['billing_city'][0]; } if (isset($meta['billing_state'])) { $this->billing_state = $meta['billing_state'][0]; } if (isset($meta['billing_postcode'])) { $this->billing_postcode = $meta['billing_postcode'][0]; } if (isset($meta['billing_country'])) { $country = $meta['billing_country'][0]; $country = fflcommerce_countries::has_country($country) ? $country : fflcommerce_countries::get_base_country(); $this->billing_country = $country; } if (isset($meta['billing_email'])) { $this->billing_email = $meta['billing_email'][0]; } if (isset($meta['billing_first_name'])) { $this->billing_phone = $meta['billing_phone'][0]; } if (isset($meta['shipping_first_name'])) { $this->shipping_first_name = $meta['shipping_first_name'][0]; } if (isset($meta['shipping_last_name'])) { $this->shipping_last_name = $meta['shipping_last_name'][0]; } if (isset($meta['shipping_company'])) { $this->shipping_company = $meta['shipping_company'][0]; } if (isset($meta['shipping_address_1'])) { $this->shipping_address_1 = $meta['shipping_address_1'][0]; } if (isset($meta['shipping_address_2'])) { $this->shipping_address_2 = $meta['shipping_address_2'][0]; } if (isset($meta['shipping_city'])) { $this->shipping_city = $meta['shipping_city'][0]; } if (isset($meta['shipping_state'])) { $this->shipping_state = $meta['shipping_state'][0]; } if (isset($meta['shipping_postcode'])) { $this->shipping_postcode = $meta['shipping_postcode'][0]; } if (isset($meta['shipping_country'])) { $country = $meta['shipping_country'][0]; $country = fflcommerce_countries::has_country($country) ? $country : fflcommerce_countries::get_base_country(); $this->shipping_country = $country; } }
/** * Validate the checkout */ public function validate_checkout() { if (fflcommerce_cart::is_empty()) { fflcommerce::add_error(sprintf(__('Sorry, your session has expired. <a href="%s">Return to homepage →</a>', 'fflcommerce'), home_url())); } // Process Discount Codes if (!empty($_POST['coupon_code'])) { $coupon = sanitize_title($_POST['coupon_code']); fflcommerce_cart::add_discount($coupon); } foreach (fflcommerce_cart::get_coupons() as $coupon) { fflcommerce_cart::is_valid_coupon($coupon); } // Checkout fields $this->posted['shipping_method'] = ''; $this->posted['shipping_service'] = ''; if (isset($_POST['shipping_method'])) { $shipping_method = fflcommerce_clean($_POST['shipping_method']); $shipping_data = explode(':', $shipping_method); $this->posted['shipping_method'] = $shipping_data[0]; $this->posted['shipping_service'] = $shipping_data[1]; } $this->posted['shiptobilling'] = isset($_POST['shiptobilling']) ? fflcommerce_clean($_POST['shiptobilling']) : ''; $this->posted['payment_method'] = isset($_POST['payment_method']) ? fflcommerce_clean($_POST['payment_method']) : ''; $this->posted['order_comments'] = isset($_POST['order_comments']) ? fflcommerce_clean($_POST['order_comments']) : ''; $this->posted['terms'] = isset($_POST['terms']) ? fflcommerce_clean($_POST['terms']) : ''; $this->posted['create_account'] = isset($_POST['create_account']) ? fflcommerce_clean($_POST['create_account']) : ''; $this->posted['account_username'] = isset($_POST['account_username']) ? fflcommerce_clean($_POST['account_username']) : ''; $this->posted['account_password'] = isset($_POST['account_password']) ? fflcommerce_clean($_POST['account_password']) : ''; $this->posted['account_password_2'] = isset($_POST['account_password_2']) ? fflcommerce_clean($_POST['account_password_2']) : ''; if (fflcommerce_cart::get_total(false) == 0) { $this->posted['payment_method'] = 'no_payment'; } // establish customer billing and shipping locations if (fflcommerce_cart::ship_to_billing_address_only()) { $this->posted['shiptobilling'] = 'true'; } $country = isset($_POST['billing_country']) ? fflcommerce_clean($_POST['billing_country']) : ''; $state = isset($_POST['billing_state']) ? fflcommerce_clean($_POST['billing_state']) : ''; $allowed_countries = FFLCommerce_Base::get_options()->get('fflcommerce_allowed_countries'); if ($allowed_countries === 'specific') { $specific_countries = FFLCommerce_Base::get_options()->get('fflcommerce_specific_allowed_countries'); if (!in_array($country, $specific_countries)) { fflcommerce::add_error(__('Invalid billing country.', 'fflcommerce')); return; } } if (fflcommerce_countries::country_has_states($country)) { $states = fflcommerce_countries::get_states($country); if (!in_array($state, array_keys($states))) { fflcommerce::add_error(__('Invalid billing state.', 'fflcommerce')); return; } } $postcode = isset($_POST['billing_postcode']) ? fflcommerce_clean($_POST['billing_postcode']) : ''; $ship_to_billing = FFLCommerce_Base::get_options()->get('fflcommerce_ship_to_billing_address_only') == 'yes'; fflcommerce_customer::set_location($country, $state, $postcode); if (FFLCommerce_Base::get_options()->get('fflcommerce_calc_shipping') == 'yes') { if ($ship_to_billing || !empty($_POST['shiptobilling'])) { fflcommerce_customer::set_shipping_location($country, $state, $postcode); } else { $country = isset($_POST['shipping_country']) ? fflcommerce_clean($_POST['shipping_country']) : ''; $state = isset($_POST['shipping_state']) ? fflcommerce_clean($_POST['shipping_state']) : ''; $postcode = isset($_POST['shipping_postcode']) ? fflcommerce_clean($_POST['shipping_postcode']) : ''; if ($allowed_countries === 'specific') { $specific_countries = FFLCommerce_Base::get_options()->get('fflcommerce_specific_allowed_countries'); if (!in_array($country, $specific_countries)) { fflcommerce::add_error(__('Invalid shipping country.', 'fflcommerce')); return; } } if (fflcommerce_countries::country_has_states($country)) { $states = fflcommerce_countries::get_states($country); if (!in_array($state, array_keys($states))) { fflcommerce::add_error(__('Invalid shipping state.', 'fflcommerce')); return; } } fflcommerce_customer::set_shipping_location($country, $state, $postcode); } } // Billing Information foreach ($this->billing_fields as $field) { $field = apply_filters('fflcommerce_billing_field', $field); $this->posted[$field['name']] = isset($_POST[$field['name']]) ? fflcommerce_clean($_POST[$field['name']]) : ''; // Format if (isset($field['format'])) { switch ($field['format']) { case 'postcode': $this->posted[$field['name']] = strtolower(str_replace(' ', '', $this->posted[$field['name']])); break; } } // Required if ($field['name'] == 'billing_state' && fflcommerce_customer::has_valid_shipping_state()) { $field['required'] = false; } if (isset($field['required']) && $field['required'] && empty($this->posted[$field['name']])) { fflcommerce::add_error($field['label'] . __(' (billing) is a required field.', 'fflcommerce')); } if ($field['name'] == 'billing_euvatno') { $vatno = isset($this->posted['billing_euvatno']) ? $this->posted['billing_euvatno'] : ''; $vatno = str_replace(' ', '', $vatno); $country = fflcommerce_tax::get_customer_country(); // strip any country code from the beginning of the number if (strpos($vatno, $country) === 0) { $vatno = substr($vatno, strlen($country)); } if ($vatno != '') { $url = 'http://isvat.appspot.com/' . $country . '/' . $vatno . '/'; $httpRequest = curl_init(); curl_setopt($httpRequest, CURLOPT_FAILONERROR, true); curl_setopt($httpRequest, CURLOPT_RETURNTRANSFER, true); curl_setopt($httpRequest, CURLOPT_HEADER, false); curl_setopt($httpRequest, CURLOPT_URL, $url); $result = curl_exec($httpRequest); curl_close($httpRequest); if ($result === 'false') { fflcommerce_log('EU VAT validation error with URL: ' . $url); fflcommerce::add_error($field['label'] . __(' (billing) is not a valid VAT Number. Leave it blank to disable VAT validation. (VAT may be charged depending on your location)', 'fflcommerce')); } else { $this->valid_euvatno = fflcommerce_countries::get_base_country() != fflcommerce_tax::get_customer_country() && fflcommerce_countries::is_eu_country(fflcommerce_tax::get_customer_country()); } } } // Validation if (isset($field['validate']) && !empty($this->posted[$field['name']])) { switch ($field['validate']) { case 'phone': if (!fflcommerce_validation::is_phone($this->posted[$field['name']])) { fflcommerce::add_error($field['label'] . __(' (billing) is not a valid number.', 'fflcommerce')); } break; case 'email': if (!fflcommerce_validation::is_email($this->posted[$field['name']])) { fflcommerce::add_error($field['label'] . __(' (billing) is not a valid email address.', 'fflcommerce')); } break; case 'postcode': if (!fflcommerce_validation::is_postcode($this->posted[$field['name']], $_POST['billing_country'])) { fflcommerce::add_error($field['label'] . __(' (billing) is not a valid postcode/ZIP.', 'fflcommerce')); } else { $this->posted[$field['name']] = fflcommerce_validation::format_postcode($this->posted[$field['name']], $_POST['billing_country']); } break; } } } // Shipping Information if (fflcommerce_shipping::is_enabled() && !fflcommerce_cart::ship_to_billing_address_only() && empty($this->posted['shiptobilling'])) { foreach ($this->shipping_fields as $field) { $field = apply_filters('fflcommerce_shipping_field', $field); if (isset($_POST[$field['name']])) { $this->posted[$field['name']] = fflcommerce_clean($_POST[$field['name']]); } else { $this->posted[$field['name']] = ''; } // Format if (isset($field['format'])) { switch ($field['format']) { case 'postcode': $this->posted[$field['name']] = strtolower(str_replace(' ', '', $this->posted[$field['name']])); break; } } // Required if ($field['name'] == 'shipping_state' && fflcommerce_customer::has_valid_shipping_state()) { $field['required'] = false; } if (isset($field['required']) && $field['required'] && empty($this->posted[$field['name']])) { fflcommerce::add_error($field['label'] . __(' (shipping) is a required field.', 'fflcommerce')); } // Validation if (isset($field['validate']) && !empty($this->posted[$field['name']])) { switch ($field['validate']) { case 'postcode': if (!fflcommerce_validation::is_postcode($this->posted[$field['name']], $country)) { fflcommerce::add_error($field['label'] . __(' (shipping) is not a valid postcode/ZIP.', 'fflcommerce')); } else { $this->posted[$field['name']] = fflcommerce_validation::format_postcode($this->posted[$field['name']], $country); } break; } } } } if ($this->must_register && empty($this->posted['create_account'])) { fflcommerce::add_error(__('Sorry, you must agree to creating an account', 'fflcommerce')); } if ($this->must_register || empty($user_id) && $this->posted['create_account']) { if (!$this->show_signup) { fflcommerce::add_error(__('Sorry, the shop owner has disabled guest purchases.', 'fflcommerce')); } if (empty($this->posted['account_username'])) { fflcommerce::add_error(__('Please enter an account username.', 'fflcommerce')); } if (empty($this->posted['account_password'])) { fflcommerce::add_error(__('Please enter an account password.', 'fflcommerce')); } if ($this->posted['account_password_2'] !== $this->posted['account_password']) { fflcommerce::add_error(__('Passwords do not match.', 'fflcommerce')); } // Check the username if (!validate_username($this->posted['account_username'])) { fflcommerce::add_error(__('Invalid email/username.', 'fflcommerce')); } elseif (username_exists($this->posted['account_username'])) { fflcommerce::add_error(__('An account is already registered with that username. Please choose another.', 'fflcommerce')); } // Check the e-mail address if (email_exists($this->posted['billing_email'])) { fflcommerce::add_error(__('An account is already registered with your email address. Please login.', 'fflcommerce')); } } // Terms if (!isset($_POST['update_totals']) && empty($this->posted['terms']) && fflcommerce_get_page_id('terms') > 0) { fflcommerce::add_error(__('You must accept our Terms & Conditions.', 'fflcommerce')); } if (fflcommerce_cart::needs_shipping()) { // Shipping Method $available_methods = fflcommerce_shipping::get_available_shipping_methods(); if (!isset($available_methods[$this->posted['shipping_method']])) { fflcommerce::add_error(__('Invalid shipping method.', 'fflcommerce')); } } }
/** * Admin Notices for conditions under which FuturePay is available on a Shop */ public function futurepay_notices() { if ($this->enabled == 'no') { return; } if (!in_array(FFLCommerce_Base::get_options()->get('fflcommerce_currency'), $this->allowed_currency)) { echo '<div class="error"><p>' . sprintf(__('The FuturePay gateway accepts payments in currencies of %s. Your current currency is %s. FuturePay won\'t work until you change the FFL Commerce currency to an accepted one. FuturePay is currently disabled on the Payment Gateways settings tab.', 'fflcommerce'), implode(', ', $this->allowed_currency), FFLCommerce_Base::get_options()->get('fflcommerce_currency')) . '</p></div>'; FFLCommerce_Base::get_options()->set('fflcommerce_futurepay_enabled', 'no'); } if (!in_array($this->shop_base_country, $this->merchant_countries)) { $country_list = array(); foreach ($this->merchant_countries as $this_country) { $country_list[] = fflcommerce_countries::get_country($this_country); } echo '<div class="error"><p>' . sprintf(__('The FuturePay gateway is available to merchants from: %s. Your country is: %s. FuturePay won\'t work until you change the FFL Commerce Shop Base country to an accepted one. FuturePay is currently disabled on the Payment Gateways settings tab.', 'fflcommerce'), implode(', ', $country_list), fflcommerce_countries::get_base_country()) . '</p></div>'; FFLCommerce_Base::get_options()->set('fflcommerce_futurepay_enabled', 'no'); } }