PK œqhYξΆJ‚ίFίF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/outtheboxministry.org/xhr/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/outtheboxministry.org/xhr/products.php

<?php 
if ($f == 'products') {
    $data['status'] = 400;
    if ($s == 'create' && Wo_CheckSession($hash_id) === true) {
        if ($wo['config']['who_upload'] == 'pro' && $wo['user']['is_pro'] == 0 && !Wo_IsAdmin() && !empty($_FILES['postPhotos'])) {
            $errors[] = $error_icon . $wo['lang']['free_plan_upload_pro'];
        }
        if (empty($_POST['name']) || empty($_POST['category']) || empty($_POST['description'])) {
            $errors[] = $error_icon . $wo['lang']['please_check_details'];
        } else if (empty($_POST['price'])) {
            $errors[] = $error_icon . $wo['lang']['please_choose_price'];
        } else if (!is_numeric($_POST['price'])) {
            $errors[] = $error_icon . $wo['lang']['please_choose_c_price'];
        } else if ($_POST['price'] == '0.00') {
            $errors[] = $error_icon . $wo['lang']['please_choose_price'];
        } else if (empty($_FILES['postPhotos']['name'])) {
            $errors[] = $error_icon . $wo['lang']['please_upload_image'];
        } else if($wo['config']['store_system'] == 'on' && (empty($_POST['units']) || !is_numeric($_POST['units']) || $_POST['units'] < 1)){
            $errors[] = $error_icon . $wo['lang']['total_item_not_empty'];
        }
        if (isset($_FILES['postPhotos']['name'])) {
            $allowed = array(
                'gif',
                'png',
                'jpg',
                'jpeg'
            );
            for ($i = 0; $i < count($_FILES['postPhotos']['name']); $i++) {
                $new_string = pathinfo($_FILES['postPhotos']['name'][$i]);
                if (!in_array(strtolower($new_string['extension']), $allowed)) {
                    $errors[] = $error_icon . $wo['lang']['please_check_details'];
                }
            }
        }
        $type = 0;
        if (!empty($_POST['type'])) {
            $type = 1;
        }
        $currency = 0;
        if (isset($_POST['currency'])) {
            if (in_array($_POST['currency'], array_keys($wo['currencies']))) {
                $currency = Wo_Secure($_POST['currency']);
            }
        }
        $units = 0;
        if (!empty($_POST['units']) && is_numeric($_POST['units']) && $_POST['units'] > 0) {
            $units = Wo_Secure($_POST['units']);
        }
        if (empty($errors)) {
            $sub_category = '';
            if (!empty($_POST['product_sub_category']) && !empty($wo['products_sub_categories'][$_POST['category']])) {
                foreach ($wo['products_sub_categories'][$_POST['category']] as $key => $value) {
                    if ($value['id'] == $_POST['product_sub_category']) {
                        $sub_category = $value['id'];
                    }
                }
            }
            $lat = '';
            $lng = '';
            if (!empty($_POST['lat-product'])) {
                if (is_numeric($_POST['lat-product'])) {
                    $lat = $_POST['lat-product'];
                }
            }
            if (!empty($_POST['lng-product'])) {
                if (is_numeric($_POST['lng-product'])) {
                    $lng = $_POST['lng-product'];
                }
            }
            $page_id = 0;
            if (!empty($_POST['page_id']) && is_numeric($_POST['page_id']) && $_POST['page_id'] > 0 && Wo_IsPageOnwer(Wo_Secure($_POST['page_id']))) {
                $page_id = Wo_Secure($_POST['page_id']);
            }
            $price              = Wo_Secure($_POST['price']);
            $product_data_array = array(
                'user_id' => $wo['user']['user_id'],
                'name' => Wo_Secure($_POST['name']),
                'category' => Wo_Secure($_POST['category']),
                'sub_category' => $sub_category,
                'description' => Wo_Secure($_POST['description'],1,true,1),
                'time' => Wo_Secure(time()),
                'price' => $price,
                'type' => $type,
                'location' => Wo_Secure($_POST['location']),
                'currency' => $currency,
                'active' => ($wo['config']['store_review_system'] == 'off' ? 1 : 0),
                'lat' => Wo_Secure($lat),
                'lng' => Wo_Secure($lng),
                'units' => $units,
                'page_id' => $page_id
            );
            $fields = Wo_GetCustomFields('product'); 
            if (!empty($fields)) {
                foreach ($fields as $key => $field) {
                    if ($field['required'] == 'on' && empty($_POST['fid_'.$field['id']])) {
                        $errors[] = $error_icon . $wo['lang']['please_check_details'];
                        header("Content-type: application/json");
                        echo json_encode(array(
                            'errors' => $errors
                        ));
                        exit();
                    }
                    elseif (!empty($_POST['fid_'.$field['id']])) {
                        $product_data_array['fid_'.$field['id']] = Wo_Secure($_POST['fid_'.$field['id']]);
                    }
                }
            }
            $product_data       = Wo_RegisterProduct($product_data_array);
            $product_id         = 0;
            if (!$product_data) {
                $errors[] = $error_icon . $wo['lang']['please_check_details'];
                header("Content-type: application/json");
                echo json_encode(array(
                    'errors' => $errors
                ));
                exit();
            }
            $product_id = $product_data;
            $post_data  = array(
                'user_id' => Wo_Secure($wo['user']['user_id']),
                'product_id' => Wo_Secure($product_id),
                'postPrivacy' => Wo_Secure(0),
                'time' => time(),
                'page_id' => $page_id,
                'active' => ($wo['config']['store_review_system'] == 'off' ? 1 : 0),
            );
            $id         = Wo_RegisterPost($post_data);
            if (count($_FILES['postPhotos']['name']) > 0 && !empty($id) && $id > 0) {
                for ($i = 0; $i < count($_FILES['postPhotos']['name']); $i++) {
                    $fileInfo = array(
                        'file' => $_FILES["postPhotos"]["tmp_name"][$i],
                        'name' => $_FILES['postPhotos']['name'][$i],
                        'size' => $_FILES["postPhotos"]["size"][$i],
                        'type' => $_FILES["postPhotos"]["type"][$i],
                        'types' => 'jpg,png,jpeg,gif'
                    );
                    $file     = Wo_ShareFile($fileInfo, 1);
                    if (!empty($file)) {
                        $media_album = Wo_RegisterProductMedia($product_id, $file['filename']);
                    }
                }
            }
            $data = array(
                'status' => 200,
                'href' => Wo_SeoLink('index.php?link1=post&id=' . $id)
            );
            if ($wo['config']['store_review_system'] != 'off') {
                $data['message'] = $wo['lang']['your_product_is_under_review'];
            }
        }
        header("Content-type: application/json");
        if (isset($errors)) {
            echo json_encode(array(
                'errors' => $errors
            ));
        } else {
            echo json_encode($data);
        }
        exit();
    }
    if ($s == 'edit' && Wo_CheckSession($hash_id) === true) {
        if (empty($_POST['name']) || empty($_POST['category']) || empty($_POST['description'])) {
            $errors[] = $error_icon . $wo['lang']['please_check_details'];
        } else if (empty($_POST['price'])) {
            $errors[] = $error_icon . $wo['lang']['please_choose_price'];
        } else if (!is_numeric($_POST['price'])) {
            $errors[] = $error_icon . $wo['lang']['please_choose_c_price'];
        } else if ($_POST['price'] == '0.00') {
            $errors[] = $error_icon . $wo['lang']['please_choose_price'];
        } else if($wo['config']['store_system'] == 'on' && (empty($_POST['units']) || !is_numeric($_POST['units']) || $_POST['units'] < 1)){
            $errors[] = $error_icon . $wo['lang']['total_item_not_empty'];
        }
        if (isset($_FILES['postPhotos']['name'])) {
            $allowed = array(
                'gif',
                'png',
                'jpg',
                'jpeg'
            );
            for ($i = 0; $i < count($_FILES['postPhotos']['name']); $i++) {
                $new_string = pathinfo($_FILES['postPhotos']['name'][$i]);
                if (!in_array(strtolower($new_string['extension']), $allowed)) {
                    $errors[] = $error_icon . $wo['lang']['please_check_details'];
                }
            }
        }
        $type = 0;
        if (!empty($_POST['type'])) {
            $type = 1;
        }
        $currency = 0;
        if (isset($_POST['currency'])) {
            if (in_array($_POST['currency'], array_keys($wo['currencies']))) {
                $currency = Wo_Secure($_POST['currency']);
            }
        }
        $units = 0;
        if (!empty($_POST['units']) && is_numeric($_POST['units']) && $_POST['units'] > 0) {
            $units = Wo_Secure($_POST['units']);
        }
        if (empty($errors)) {
            $sub_category = '';
            if (!empty($_POST['product_sub_category']) && !empty($wo['products_sub_categories'][$_POST['category']])) {
                foreach ($wo['products_sub_categories'][$_POST['category']] as $key => $value) {
                    if ($value['id'] == $_POST['product_sub_category']) {
                        $sub_category = $value['id'];
                    }
                }
            }
            $price              = Wo_Secure($_POST['price']);
            $product_data_array = array(
                'name' => $_POST['name'],
                'category' => $_POST['category'],
                'sub_category' => $sub_category,
                'description' => $_POST['description'],
                'price' => $price,
                'location' => Wo_Secure($_POST['location']),
                'type' => $type,
                'currency' => $currency,
                'units' => $units,
            );

            $fields = Wo_GetCustomFields('product'); 
            if (!empty($fields)) {
                foreach ($fields as $key => $field) {
                    if ($field['required'] == 'on' && empty($_POST['fid_'.$field['id']])) {
                        $errors[] = $error_icon . $wo['lang']['please_check_details'];
                        header("Content-type: application/json");
                        echo json_encode(array(
                            'errors' => $errors
                        ));
                        exit();
                    }
                    elseif (!empty($_POST['fid_'.$field['id']])) {
                        $product_data_array['fid_'.$field['id']] = Wo_Secure($_POST['fid_'.$field['id']]);
                    }
                }
            }

            $product_data       = Wo_UpdateProductData($_POST['product_id'], $product_data_array);
            $product_id         = $_POST['product_id'];
            if (!$product_data) {
                $errors[] = $error_icon . $wo['lang']['please_check_details'];
                header("Content-type: application/json");
                echo json_encode(array(
                    'errors' => $errors
                ));
                exit();
            }
            $id = Wo_GetPostIDFromProdcutID($product_id);
            if (isset($_FILES['postPhotos']['name'])) {
                if (count($_FILES['postPhotos']['name']) > 0 && !empty($id) && $id > 0) {
                    for ($i = 0; $i < count($_FILES['postPhotos']['name']); $i++) {
                        $fileInfo = array(
                            'file' => $_FILES["postPhotos"]["tmp_name"][$i],
                            'name' => $_FILES['postPhotos']['name'][$i],
                            'size' => $_FILES["postPhotos"]["size"][$i],
                            'type' => $_FILES["postPhotos"]["type"][$i],
                            'types' => 'jpg,png,jpeg,gif'
                        );
                        $file     = Wo_ShareFile($fileInfo, 1);
                        if (!empty($file)) {
                            $media_album = Wo_RegisterProductMedia($product_id, $file['filename']);
                        }
                    }
                }
            }
            if (!empty($_POST['deleted_images_ids'])) {
                $images_array = explode(',', $_POST['deleted_images_ids']);
                if (!empty($images_array)) {
                    $product_data = Wo_GetProduct($product_id);
                    foreach ($images_array as $key => $value) {
                        $image = Wo_ProductImageData(array('id' => $value));
                        if (!empty($image)) {
                            $explode2    = @end(explode('.', $image['image']));
                            $explode3    = @explode('.', $image['image']);
                            $small_image = $explode3[0] . '_small.' . $explode2;

                            $product = Wo_GetProduct($image['product_id']);
                            if (!empty($product) && $wo['user']['id'] == $product['user_id']) {
                                $deleted = Wo_DeleteProductImage($value);
                                if ($deleted) {
                                    if (($wo['config']['amazone_s3'] == 1 || $wo['config']['wasabi_storage'] == 1 || $wo['config']['ftp_upload'] == 1 || $wo['config']['spaces'] == 1 || $wo['config']['cloud_upload'] == 1)) {
                                        Wo_DeleteFromToS3($image['image']);
                                        Wo_DeleteFromToS3($small_image);
                                    }
                                    @unlink($image['image']);
                                    @unlink($small_image);
                                }
                            }
                        }
                    }
                }
            }
            $data = array(
                'status' => 200,
                'href' => Wo_SeoLink('index.php?link1=post&id=' . $id)
            );
        }
        header("Content-type: application/json");
        if (isset($errors)) {
            echo json_encode(array(
                'errors' => $errors
            ));
        } else {
            echo json_encode($data);
        }
        exit();
    }
    if ($s == 'add_cart') {
        if (!empty($_POST['product_id']) && is_numeric($_POST['product_id']) && $_POST['product_id'] > 0) {
            $is_added = $db->where('product_id', Wo_Secure($_POST['product_id']))->where('user_id',$wo['user']['user_id'])->getOne(T_USERCARD);
            if (!empty($is_added)) {
                $product_data = Wo_GetProduct(Wo_Secure($_POST['product_id']));
                if (!empty($product_data) && !empty($product_data['units']) && $product_data['units'] > $is_added->units) {
                    $db->where('id',$is_added->id)->update(T_USERCARD,array('units' => $db->inc(1)));
                }
                // $db->where('product_id',Wo_Secure($_POST['product_id']))->where('user_id',$wo['user']['user_id'])->delete(T_USERCARD);
                $data['status'] = 200;
                $data['type'] = 'removed';
            }
            else{
                $qty = 1;
                if (!empty($_POST['qty']) && is_numeric($_POST['qty']) && $_POST['qty'] > 0) {
                    $qty = Wo_Secure($_POST['qty']);
                }
                $db->insert(T_USERCARD,array('user_id' => $wo['user']['user_id'],
                                         'units' => $qty,
                                         'product_id' => Wo_Secure($_POST['product_id'])));
                $data['status'] = 200;
                $data['type'] = 'added';
            }
            $data['count'] = $db->where('user_id',$wo['user']['user_id'])->getValue(T_USERCARD,'COUNT(*)');
            if ($data['count'] < 1) {
                $data['count'] = '';
            }
        }
        else{
            $data['message'] = $error_icon . $wo['lang']['please_check_details'];
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'change_qty') {
        if (!empty($_POST['product_id']) && is_numeric($_POST['product_id']) && $_POST['product_id'] > 0 && !empty($_POST['qty']) && is_numeric($_POST['qty']) && $_POST['qty'] > 0) {
            $product = Wo_GetProduct(Wo_Secure($_POST['product_id']));
            $qty = Wo_Secure($_POST['qty']);
            if ($product['units'] >= $qty) {
                $db->where('product_id',$product['id'])->where('user_id',$wo['user']['user_id'])->update(T_USERCARD,array('units' => $qty));
                $data['status'] = 200;
            }
        }
        else{
            $data['message'] = $error_icon . $wo['lang']['please_check_details'];
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'remove_cart') {
        if (!empty($_POST['product_id']) && is_numeric($_POST['product_id']) && $_POST['product_id'] > 0) {
            $is_added = $db->where('product_id', Wo_Secure($_POST['product_id']))->where('user_id',$wo['user']['user_id'])->getOne(T_USERCARD);
            if (!empty($is_added)) {
                $db->where('product_id',Wo_Secure($_POST['product_id']))->where('user_id',$wo['user']['user_id'])->delete(T_USERCARD);
                $data['status'] = 200;
                $data['count'] = $db->where('user_id',$wo['user']['user_id'])->getValue(T_USERCARD,'COUNT(*)');
                if ($data['count'] < 1) {
                    $data['count'] = '';
                }
            }
        }
        else{
            $data['message'] = $error_icon . $wo['lang']['please_check_details'];
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'check_wallet') {
        $items = $db->where('user_id',$wo['user']['user_id'])->get(T_USERCARD);
        $data['topup'] = 'show';
        $total = 0;
        if (!empty($items)) {
            foreach ($items as $key => $item) {
                $product = Wo_GetProduct($item->product_id);
                $total += ($product['price'] * $item->units);
            }
            $data['topup'] = ($wo['user']['wallet'] < $total ? 'show' : 'hide');
        }
        $data['status'] = 200;
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'buy') {
        $data['status'] = 400;
        if (!empty($_POST['address_id']) && is_numeric($_POST['address_id']) && $_POST['address_id'] > 0) {
            $address = $db->where('id',Wo_Secure($_POST['address_id']))->where('user_id',$wo['user']['user_id'])->getOne(T_USER_ADDRESS);
            if (!empty($address)) {
                $items = $db->where('user_id',$wo['user']['user_id'])->get(T_USERCARD);
                $html = '';
                $total = 0;
                $insert = array();
                $wo['main_product'] = '';

                if (!empty($items)) {
                    foreach ($items as $key => $item) {
                        $product = $wo['main_product'] = Wo_GetProduct($item->product_id);
                        if ($item->units <= $product['units']) {
                            if (!empty($wo['currencies']) && !empty($wo['currencies'][$product['currency']]) && $wo['currencies'][$product['currency']]['text'] != $wo['config']['currency'] && !empty($wo['config']['exchange']) && !empty($wo['config']['exchange'][$wo['currencies'][$product['currency']]['text']])) {
                                $total += (($product['price'] / $wo['config']['exchange'][$wo['currencies'][$product['currency']]['text']]) * $item->units);
                            }
                            else{
                                $total += ($product['price'] * $item->units);
                            }
                            if (!in_array($product['user_id'], array_keys($insert))) {
                                $f_price = $product['price'];
                                if (!empty($wo['config']['exchange']) && !empty($wo['config']['exchange'][$wo['currencies'][$product['currency']]['text']])) {
                                    $f_price = ($product['price'] / $wo['config']['exchange'][$wo['currencies'][$product['currency']]['text']]);
                                }
                                $insert[$product['user_id']] = array();
                                $insert[$product['user_id']][] = array('product_id' => $product['id'],
                                                                       'price' => $f_price,
                                                                       'units' => $item->units);
                            }
                            else{
                                $f_price = $product['price'];
                                if (!empty($wo['config']['exchange']) && !empty($wo['config']['exchange'][$wo['currencies'][$product['currency']]['text']])) {
                                    $f_price = ($product['price'] / $wo['config']['exchange'][$wo['currencies'][$product['currency']]['text']]);
                                }
                                $insert[$product['user_id']][] = array('product_id' => $product['id'],
                                                                       'price' => $f_price,
                                                                       'units' => $item->units);
                            }
                        }
                        else{
                            $data['message'] = $error_icon . $wo['lang']['some_products_units'];
                            header('Content-Type: application/json');
                            echo json_encode($data);
                            exit();
                        }
                    }
                    if ($wo['user']['wallet'] < $total) {
                        $data['message'] = $error_icon . $wo["lang"]["please_top_up_wallet"];
                        header('Content-Type: application/json');
                        echo json_encode($data);
                        exit();
                    }

                    if (!empty($insert)) {
                        foreach ($insert as $key => $value) {
                            $hash_id = uniqid(rand(11111,999999));
                            $total = 0;
                            $total_commission = 0;
                            $total_final_price = 0;
                            foreach ($value as $key2 => $value2) {
                                $db->where('id',$value2['product_id'])->update(T_PRODUCTS,array('units' => $db->dec($value2['units'])));
                                $store_commission = 0;
                                if (!empty($wo['config']['store_commission'])) {
                                    $store_commission = round((($wo['config']['store_commission'] * ($value2['price'] * $value2['units'])) / 100), 2);
                                }
                                $total += ($value2['price'] * $value2['units']);
                                $total_commission += $store_commission;
                                $total_final_price += ($value2['price'] * $value2['units']) - $store_commission;
                                    
                                $db->insert(T_USER_ORDERS,array('user_id' => $wo['user']['user_id'],
                                                           'product_owner_id' => $key,
                                                           'product_id' => $value2['product_id'],
                                                           'price' => ($value2['price'] * $value2['units']),
                                                           'commission' => $store_commission,
                                                           'final_price' => ($value2['price'] * $value2['units']) - $store_commission,
                                                           'hash_id' => $hash_id,
                                                           'units' => $value2['units'],
                                                           'status' => 'placed',
                                                           'address_id' => $address->id,
                                                           'time' => time()));
                            }
                            $db->where('user_id',$wo['user']['user_id'])->update(T_USERS,array('wallet' => $db->dec($total)));
                            $db->where('user_id',$key)->update(T_USERS,array('balance' => $db->inc($total_final_price)));
                            $notes = $wo['lang']['product_purchase'];
                            $notes_2 = $wo['lang']['product_sale'];
                            mysqli_query($sqlConnect, "INSERT INTO " . T_PAYMENT_TRANSACTIONS . " (`userid`, `kind`, `amount`, `notes`) VALUES ({$wo['user']['user_id']}, 'PURCHASE', {$total}, '{$notes}')");
                            mysqli_query($sqlConnect, "INSERT INTO " . T_PAYMENT_TRANSACTIONS . " (`userid`, `kind`, `amount`, `notes`) VALUES ({$key}, 'SALE', {$total_final_price}, '{$notes_2}')");
                            $db->insert(T_PURCHAES,array('user_id' => $wo['user']['user_id'],
                                                             'order_hash_id' => $hash_id,
                                                             'price' => $total,
                                                             'data' => json_encode(array('name' => !empty($wo['main_product']) && !empty($wo['main_product']['name']) ? $wo['main_product']['name'] : '')),
                                                             'commission' => $total_commission,
                                                             'final_price' => $total_final_price,
                                                             'time' => time()));
                            $notification_data_array = array(
                                'notifier_id' => $wo['user']['user_id'],
                                'recipient_id' => $key,
                                'type' => 'new_orders',
                                'url' => 'index.php?link1=orders',
                                'time' => time()
                            );
                            $db->insert(T_NOTIFICATION,$notification_data_array);
                        }

                        $db->where('user_id',$wo['user']['user_id'])->delete(T_USERCARD);
                        $data['status'] = 200;
                        $data['message'] = $wo["lang"]["your_order_has_been_placed_successfully"];
                        $data['users'] = array_keys($insert);
                    }
                    else{
                        $data['message'] = $error_icon . $wo["lang"]["something_wrong"];
                    }
                }
                else{
                    $data['message'] = $error_icon . $wo["lang"]["card_is_empty"];
                }
            }
            else{
                $data['message'] = $error_icon . $wo["lang"]["address_not_found"];
            }
        }
        else{
            $data['message'] = $error_icon . $wo["lang"]["address_can_not_be_empty"];
        }
        $data['status'] = 200;
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'download') {
        if (!empty($_POST['id'])) {
            $id = Wo_Secure($_POST['id']);
            $wo['purchase'] = $db->where('order_hash_id',$id)->getOne(T_PURCHAES);
            if (!empty($wo['purchase'])) {
                $orders = $db->where('hash_id',$wo['purchase']->order_hash_id)->get(T_USER_ORDERS);
                if (!empty($orders)) {
                    $wo['total'] = 0;
                    $wo['total_commission'] = 0;
                    $wo['total_final_price'] = 0;
                    $wo['address_id'] = 0;
                    $user_id = 0;
                    $wo['html'] = '';
                    $wo['main_product'] = '';
                    foreach ($orders as $key => $order) {
                        $order->product = Wo_GetProduct($order->product_id);
                        if (empty($wo['main_product'])) {
                            $wo['main_product'] = $order->product;
                            $wo['main_product']['in_title'] = url_slug($wo['main_product']['name'], array(
                                'delimiter' => '-',
                                'limit' => 100,
                                'lowercase' => true,
                                'replacements' => array(
                                    '/\b(an)\b/i' => 'a',
                                    '/\b(example)\b/i' => 'Test'
                                )
                            ));
                        }
                        $wo['total'] += $order->price;
                        $wo['total_commission'] += $order->commission;
                        $wo['total_final_price'] += $order->final_price;
                        $wo['address_id'] = $order->address_id;
                        $user_id = $order->product['user_id'];
                        $wo['html'] .= '<tr><td><h6 class="mb-0">'.$wo['main_product']['name'].'</h6></td><td>'.number_format(($order->price/$order->units),2).'</td><td>'.$order->units.'</td><td><span class="font-weight-semibold">'.$wo['config']['currency_symbol_array'][$wo['config']['currency']].number_format(($order->price),2).'</span></td></tr>';
                    }
                    $wo['product_owner'] = Wo_UserData($user_id);
                    $wo['address'] = $db->where('id',$wo['address_id'])->getOne(T_USER_ADDRESS);
                    $wo['total'] = number_format($wo['total'],2);
                    $wo['total_commission'] = number_format($wo['total_commission'],2);
                    $wo['total_final_price'] = number_format($wo['total_final_price'],2);
                    $wo['html'] = Wo_LoadPage('pdf/invoice');
                    $data['status'] = 200;
                    $data['html'] = $wo['html'];
                }
                else{
                    $data['message'] = $error_icon . $wo["lang"]["order_not_found"];
                }
            }
            else{
                $data['message'] = $error_icon . $wo["lang"]["you_are_not_purchased"];
            }
        }
        else{
            $data['message'] = $error_icon . $wo["lang"]["id_can_not_empty"];
        } 
        $data['status'] = 200;
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'tracking') {
        if (!empty($_POST['tracking_url']) && !empty($_POST['tracking_id']) && !empty($_POST['order_hash']) && filter_var($_POST['tracking_url'], FILTER_VALIDATE_URL)) {
            $hash_id = Wo_Secure($_POST['order_hash']);
            $tracking_url = Wo_Secure($_POST['tracking_url']);
            $tracking_id = Wo_Secure($_POST['tracking_id']);
            $order = $db->where('hash_id',$hash_id)->where('product_owner_id',$wo['user']['user_id'])->getOne(T_USER_ORDERS);
            if (!empty($order)) {
                $db->where('hash_id',$hash_id)->update(T_USER_ORDERS,array('tracking_url' => $tracking_url,
                                                                      'tracking_id' => $tracking_id));
                $notification_data_array = array(
                    'notifier_id' => $wo['user']['user_id'],
                    'recipient_id' => $order->user_id,
                    'type' => 'added_tracking',
                    'url' => 'index.php?link1=customer_order&id='.$hash_id,
                    'time' => time()
                );
                $db->insert(T_NOTIFICATION,$notification_data_array);
                $data['status'] = 200;
                $data['message'] = $wo['lang']['tracking_info_has_been_saved_successfully'];
            }
            else{
                $data['message'] = $wo['lang']['order_not_found'];
            }
        }
        else{
            if (empty($_POST['tracking_url'])) {
                $data['message'] = $wo['lang']['tracking_url_can_not_be_empty'];
            }
            elseif (empty($_POST['tracking_id'])) {
                $data['message'] = $wo['lang']['tracking_number_can_not_be_empty'];
            }
            elseif (!filter_var($_POST['tracking_url'], FILTER_VALIDATE_URL)) {
                $data['message'] = $wo['lang']['please_enter_valid_url'];
            }
            else{
                $data['message'] = $wo['lang']['please_check_details'];
            }
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'change_status') {
        if (!empty($_POST['hash_order']) && !empty($_POST['status'])) {
            $hash_id = Wo_Secure($_POST['hash_order']);
            $status = Wo_Secure($_POST['status']);
            $order = $db->where('hash_id',$hash_id)->getOne(T_USER_ORDERS);
            if (!empty($order)) {
                $types = array();
                if ($order->product_owner_id == $wo['user']['user_id']) {
                    if ($order->status == 'placed') {
                        $types = array('canceled','accepted','packed','shipped');
                    }
                    if ($order->status == 'accepted') {
                        $types = array('packed','shipped');
                    }
                    if ($order->status == 'packed') {
                        $types = array('shipped');
                    }
                    if ($order->status == 'shipped') {
                        $types = array('delivered');
                    }
                }
                elseif ($order->user_id == $wo['user']['user_id']) {
                    if ($order->status == 'shipped') {
                        $types = array('delivered');
                    }
                }
                if (in_array($status, $types)) {
                    $db->where('hash_id',$hash_id)->update(T_USER_ORDERS,array('status' => $status));
                    if ($status == 'delivered') {
                        $total = $db->where('hash_id',$hash_id)->getValue(T_USER_ORDERS,'SUM(final_price)');
                        $db->where('user_id',$order->product_owner_id)->update(T_USERS,array('wallet' => $db->inc($total)));
                        $notification_data_array = array(
                            'notifier_id' => $wo['user']['user_id'],
                            'recipient_id' => $order->product_owner_id,
                            'type' => 'status_changed',
                            'url' => 'index.php?link1=order&id='.$hash_id,
                            'time' => time()
                        );
                        $db->insert(T_NOTIFICATION,$notification_data_array);
                        $data['recipient_id'] = $order->product_owner_id;
                    }
                    else{
                        $notification_data_array = array(
                            'notifier_id' => $wo['user']['user_id'],
                            'recipient_id' => $order->user_id,
                            'type' => 'status_changed',
                            'url' => 'index.php?link1=customer_order&id='.$hash_id,
                            'time' => time()
                        );
                        $db->insert(T_NOTIFICATION,$notification_data_array);
                        $data['recipient_id'] = $order->user_id;
                    }
                        
                    $data['status'] = 200;
                }
            }
            else{
                $data['message'] = $wo['lang']['order_not_found'];
            }
        }
        else{
            $data['message'] = $wo['lang']['please_check_details'];
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'refund') {
        if (!empty($_POST['hash_order']) && !empty($_POST['message'])) {
            $hash = Wo_Secure($_POST['hash_order']);
            $message = Wo_Secure($_POST['message']);
            $order = $db->where('hash_id',$hash)->where('user_id',$wo['user']['user_id'])->getOne(T_USER_ORDERS);
            if (!empty($order)) {
                $db->insert(T_REFUND,array('order_hash_id' => $hash,
                                          'user_id' => $wo['user']['user_id'],
                                          'description' => $message,
                                          'time' => time()));
                $notif_data = array(
                    'recipient_id' => 0,
                    'type' => 'refund',
                    'admin' => 1,
                    'time' => time()
                );
                $db->insert(T_NOTIFICATION,$notif_data);
                $data['status'] = 200;
                $data['message'] = $wo['lang']['your_request_is_under_review'];

            }
            else{
                $data['message'] = $wo['lang']['order_not_found'];
            }
        }
        else{
            if (empty($_POST['message'])) {
                $data['message'] = $wo['lang']['please_explain_the_reason'];
            }
            else{
                $data['message'] = $wo['lang']['please_check_details'];
            } 
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'review') {
        if (!empty($_POST['rating']) && in_array($_POST['rating'], array(1,2,3,4,5)) && !empty($_POST['review']) && !empty($_POST['product_id']) && is_numeric($_POST['product_id']) && $_POST['product_id'] > 0) {
            $product_id = Wo_Secure($_POST['product_id']);
            $rating = Wo_Secure($_POST['rating']);
            $review = Wo_Secure($_POST['review']);
            $files = array();
            if (!empty($_FILES['images'])) {
                foreach ($_FILES['images']['name'] as $key => $value) {
                    $file_info = array(
                        'file' => $_FILES['images']['tmp_name'][$key],
                        'size' => $_FILES['images']['size'][$key],
                        'name' => $_FILES['images']['name'][$key],
                        'type' => $_FILES['images']['type'][$key]
                    );
                    $file_upload = Wo_ShareFile($file_info);
                    if (!empty($file_upload) && !empty($file_upload['filename'])) {
                        $files[] = $file_upload['filename'];
                    }
                }
            }
            $id = $db->insert(T_PRODUCT_REVIEW,array('user_id' => $wo['user']['user_id'],
                                           'product_id' => $product_id,
                                           'review' => $review,
                                           'time' => time(),
                                           'star' => $rating));
            if (!empty($id)) {
                if (!empty($files)) {
                    foreach ($files as $key => $value) {
                        $db->insert(T_ALBUMS_MEDIA,array('review_id' => $id,
                                                         'image' => $value));
                    }
                }
                $product = Wo_GetProduct($product_id);
                $notification_data_array = array(
                    'notifier_id' => $wo['user']['user_id'],
                    'recipient_id' => $product['user_id'],
                    'type' => 'new_review',
                    'url' => 'index.php?link1=post&id='.$product['seo_id'],
                    'time' => time()
                );
                $db->insert(T_NOTIFICATION,$notification_data_array);
                    
                $data['status'] = 200;
                $data['message'] = $wo["lang"]["review_has_been_sent_successfully"];
                $data['recipient_id'] = $product['user_id'];
            }
            else{
                $data['message'] = $wo["lang"]["something_wrong"];
            }
        }
        else{
            if (empty($_POST['rating'])) {
                $data['message'] = $wo['lang']['rating_can_not_be_empty'];
            }
            elseif (empty($_POST['review'])) {
                $data['message'] = $wo['lang']['review_can_not_be_empty'];
            }
            else{
                $data['message'] = $wo['lang']['please_check_details'];
            }
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'load_purchase') {
        $wo['html'] = '';
        if (!empty($_POST['id']) && is_numeric($_POST['id']) && $_POST['id'] > 0) {
            $wo['purchased'] = $db->where('user_id', $wo['user']['user_id'])->where('id',Wo_Secure($_POST['id']),'<')->orderBy('id', 'DESC')->get(T_PURCHAES, 20);
            if (!empty($wo['purchased'])) {
                foreach ($wo['purchased'] as $key => $wo['purchase']) {
                    $wo['purchase']->data = json_decode($wo['purchase']->data,true);
                    $wo['purchase']->type = $wo['lang']['order'];
                    $wo['purchase']->date = Wo_Time_Elapsed_String($wo['purchase']->time);
                    $wo['purchase']->url = Wo_SeoLink('index.php?link1=customer_order&id=' . $wo['purchase']->order_hash_id);
                    $wo['html']     .= Wo_LoadPage('purchased/list');
                }
                $data['status'] = 200;
            }
        }
        $data['html'] = $wo['html'];
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'load_orders') {
        $wo['html'] = '';
        if (!empty($_POST['id']) && is_numeric($_POST['id']) && $_POST['id'] > 0) {
            $wo['orders'] = $db->where('product_owner_id',$wo['user']['user_id'])->where('id',Wo_Secure($_POST['id']),'<')->orderBy('id', 'DESC')->groupBy('hash_id')->get(T_USER_ORDERS,10);

            if (!empty($wo['orders'])) {
                foreach ($wo['orders'] as $key => $wo['order']) {
                    $wo['product'] = $db->where('id', $wo['order']->product_id)->getOne(T_PRODUCTS, array('name'));
                    $wo['count'] = $db->where('hash_id',$wo['order']->hash_id)->getValue(T_USER_ORDERS,'count(*)');
                    $wo['items_count'] = $db->where('hash_id',$wo['order']->hash_id)->getValue(T_USER_ORDERS,'sum(units)');
                    $wo['price'] = $db->where('hash_id',$wo['order']->hash_id)->getValue(T_USER_ORDERS,'sum(price)');
                    $wo['price'] = number_format($wo['price'],2);
                    $wo['html'] .= Wo_LoadPage('orders/list');
                }
                $data['status'] = 200;
            }
        }
        $data['html'] = $wo['html'];
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'load_reviews') {
        $wo['html'] = '';
        if (!empty($_POST['id']) && is_numeric($_POST['id']) && $_POST['id'] > 0 && !empty($_POST['product_id']) && is_numeric($_POST['product_id']) && $_POST['product_id'] > 0) {
            $wo['reviews'] = $db->where('product_id',Wo_Secure($_POST['product_id']))->where('id',Wo_Secure($_POST['id']),'<')->orderBy('id', 'DESC')->get(T_PRODUCT_REVIEW,20);

            if (!empty($wo['reviews'])) {
                foreach ($wo['reviews'] as $key => $value) {
                    $wo['review_class'] = 'five_star';
                    $wo['review_stars'] = '5 β˜…β˜…β˜…β˜…β˜…';
                    if ($value->star == 1) {
                        $wo['review_class'] = 'one_star';
                        $wo['review_stars'] = '1 β˜…';
                    } else if ($value->star == 2) {
                        $wo['review_stars'] = '2 β˜…β˜…';
                        $wo['review_class'] = 'two_star';
                    } else if ($value->star == 3) {
                        $wo['review_stars'] = '3 β˜…β˜…β˜…';
                        $wo['review_class'] = 'three_star';
                    } else if ($value->star == 4) {
                        $wo['review_stars'] = '4 β˜…β˜…β˜…β˜…';
                        $wo['review_class'] = 'four_star';
                    }
                    $wo['review'] = GetReview($value->id);
                    $wo['html'] .= Wo_LoadPage('products/review');
                }
                $data['status'] = 200;
            }
        }
        $data['html'] = $wo['html'];
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'get_reviews') {
        $data['status'] = 400;
        $wo['html'] = '';
        if (!empty($_POST['id']) && is_numeric($_POST['id']) && $_POST['id'] > 0) {
            $wo['reviews'] = $db->where('product_id',Wo_Secure($_POST['id']))->orderBy('id', 'DESC')->get(T_PRODUCT_REVIEW,20);
            if (!empty($wo['reviews'])) {
                foreach ($wo['reviews'] as $key => $value) {
                    $wo['review_class'] = 'five_star';
                    $wo['review_stars'] = '5 β˜…β˜…β˜…β˜…β˜…';
                    if ($value->star == 1) {
                        $wo['review_class'] = 'one_star';
                        $wo['review_stars'] = '1 β˜…';
                    } else if ($value->star == 2) {
                        $wo['review_stars'] = '2 β˜…β˜…';
                        $wo['review_class'] = 'two_star';
                    } else if ($value->star == 3) {
                        $wo['review_stars'] = '3 β˜…β˜…β˜…';
                        $wo['review_class'] = 'three_star';
                    } else if ($value->star == 4) {
                        $wo['review_stars'] = '4 β˜…β˜…β˜…β˜…';
                        $wo['review_class'] = 'four_star';
                    }
                    $wo['review'] = GetReview($value->id);
                    $wo['html'] .= Wo_LoadPage('products/review');
                }
                $data['html'] = $wo['html'];
                $data['status'] = 200;
            }
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    if ($s == 'load_users_products') {
        $data['status'] = 400;
        $wo['html'] = '';
        if (!empty($_POST['id']) && is_numeric($_POST['id']) && $_POST['id'] > 0 && !empty($_POST['user_id']) && is_numeric($_POST['user_id']) && $_POST['user_id'] > 0) {
            $products = Wo_GetProducts(array('user_id' => Wo_Secure($_POST['user_id']) , 'limit' => 20 , 'after_id' => Wo_Secure($_POST['id'])));
            if (!empty($products)) {
                foreach ($products as $key => $wo['product']) {
                    $wo['html'] .= Wo_LoadPage('timeline/product-list');
                }
                $data['html'] = $wo['html'];
                $data['status'] = 200;
            }
        }
        header("Content-type: application/json");
        echo json_encode($data);
        exit();
    }
    // if ($s == 'delete_image_by_id') {
    //     $data['status'] = 400;
    //     if (!empty($_POST['image_id']) && is_numeric($_POST['image_id']) && $_POST['image_id'] > 0) {
    //         $image = Wo_ProductImageData(array('id' => $_POST['image_id']));
    //         if (!empty($image)) {
    //             $product = Wo_GetProduct($image['product_id']);
    //             if (!empty($product) && $wo['user']['id'] == $product['user_id']) {
    //                 $deleted = Wo_DeleteProductImage($_POST['image_id']);
    //                 if ($deleted) {
    //                     @unlink($image['image']);
    //                     $data['status'] = 200;
    //                 }
    //             }
    //         }
    //     }
    //     header("Content-type: application/json");
    //     echo json_encode($data);
    //     exit();
    // }
}