function fn_twg_api_set_cart_user_data($user_data, $response, $lang_code = CART_LANGUAGE) { $cart =& $_SESSION['cart']; // User update or registration $_user = fn_twg_parse_api_object($user_data, 'users'); $user = fn_twg_check_api_user_data($_user, 'C', $lang_code); if (empty($user)) { if (!fn_twg_set_internal_errors($response, 'ERROR_FAIL_UPDATE_USER')) { $error_text = str_replace('[object]', 'user', __('wrong_api_object_data', $lang_code)); $response->addError('ERROR_WRONG_OBJECT_DATA', $error_text); } $response->returnResponse(); } $cart['user_data'] = $user; return true; }
/** * Return order/orders info after the order placing * @param int $order_id * @param array $response */ public static function returnPlacedOrders($order_id, &$response, $items_per_page, $lang_code) { $order = self::getOrderInfo($order_id); $_error = false; $status = db_get_field('SELECT status FROM ?:orders WHERE order_id=?i', $order_id); if ($status == STATUS_PARENT_ORDER) { $child_orders = db_get_hash_single_array("SELECT order_id, status FROM ?:orders WHERE parent_order_id = ?i", array('order_id', 'status'), $order_id); $status = reset($child_orders); $order['child_orders'] = array_keys($child_orders); } if (!in_array($status, fn_get_order_paid_statuses())) { $_error = true; if ($status != 'B') { if (!empty($child_orders)) { array_unshift($child_orders, $order_id); } else { $child_orders = array(); $child_orders[] = $order_id; } $order_id_field = $status == 'N' ? 'processed_order_id' : 'failed_order_id'; $_SESSION['cart'][$order_id_field] = $child_orders; $cart =& $_SESSION['cart']; if (!empty($cart['failed_order_id'])) { $_ids = !empty($cart['failed_order_id']) ? $cart['failed_order_id'] : $cart['processed_order_id']; $_order_id = reset($_ids); $_payment_info = db_get_field("SELECT data\n FROM ?:order_data\n WHERE order_id = ?i AND type = 'P'", $_order_id); if (!empty($_payment_info)) { $_payment_info = unserialize(fn_decrypt_text($_payment_info)); } $_msg = !empty($_payment_info['reason_text']) ? $_payment_info['reason_text'] : ''; $_msg .= empty($_msg) ? __('text_order_placed_error') : ''; $response->addError('ERROR_FAIL_POST_ORDER', $_msg); $cart['processed_order_id'] = $cart['failed_order_id']; unset($cart['failed_order_id']); } elseif (!fn_twg_set_internal_errors($response, 'ERROR_FAIL_POST_ORDER')) { $response->addError('ERROR_FAIL_POST_ORDER', __('fail_post_order', $lang_code)); } } else { if (!fn_twg_set_internal_errors($response, 'ERROR_ORDER_BACKORDERED')) { $response->addError('ERROR_ORDER_BACKORDERED', __('text_order_backordered', $lang_code)); } } $response->returnResponse(); } $auth =& $_SESSION['auth']; $user = fn_get_user_info($auth['user_id']); $profile_points = !empty($user['points']) ? $user['points'] : 0; if (empty($order['child_orders'])) { $response->setData(array('order' => $order, 'profile_points' => $profile_points)); } else { $params = array(); if (empty($auth['user_id'])) { $params['order_id'] = $auth['order_ids']; } else { $params['user_id'] = $auth['user_id']; } list($orders, , $totals) = fn_get_orders($params, $items_per_page, true); $response->setMeta(!empty($totals['gross_total']) ? $totals['gross_total'] : 0, 'gross_total'); $response->setMeta(!empty($totals['totally_paid']) ? $totals['totally_paid'] : 0, 'totally_paid'); $response->setMeta($order, 'order'); $response->setResponseList(TwigmoOrder::getOrdersAsApiList($orders, $lang_code)); $response->setData($profile_points, 'profile_points'); $pagination_params = array('items_per_page' => !empty($items_per_page) ? $items_per_page : TWG_RESPONSE_ITEMS_LIMIT, 'page' => !empty($_REQUEST['page']) ? $_REQUEST['page'] : 1); fn_twg_set_response_pagination($response, $pagination_params); } }
$user_data['password1'] = ''; } $notify_user = true; if (isset($_REQUEST['page']) && $_REQUEST['page'] == 'cart') { $notify_user = false; if ($user_data['copy_address']) { $profile_fields = fn_get_profile_fields('O'); fn_fill_address($user_data, $profile_fields); } } if (isset($user_data['fields']) && is_array($user_data['fields'])) { $user_data['fields'] = array_filter($user_data['fields'], 'fn_twg_filter_profile_fields'); } $result = fn_update_user($user_data['user_id'], $user_data, $_SESSION['auth'], !$user_data['copy_address'], $notify_user); if (!$result) { if (!fn_twg_set_internal_errors($response, 'ERROR_FAIL_CREATE_USER')) { $response->addError('ERROR_FAIL_CREATE_USER', __('twgadmin_fail_create_user')); } $response->returnResponse(); } if ($_SESSION['auth']['user_id'] == 0 && version_compare(PRODUCT_VERSION, '4.3.1', '>=')) { list($user_id, $profile_id) = $result; fn_login_user($user_id); } $_SESSION['cart']['user_data'] = fn_get_user_info($_SESSION['auth']['user_id']); $profile = fn_twg_get_user_info($_SESSION['auth']['user_id']); $profile = array_merge($profile, array('cart' => fn_twg_api_get_session_cart($_SESSION['cart'], $lang_code))); $response->setData($profile); } elseif ($meta['object'] == 'cart_profile') { // For anonymous chekcout $user_data = fn_twg_get_api_data($response, $format);