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

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/main_file/app/Http/Controllers/   drwxrwxr-x
Free 13.08 GB of 57.97 GB (22.56%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     CreditNoteController.php (7.37 KB)      -rw-rw-r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace App\Http\Controllers;

use 
App\Models\CreditNote;
use 
App\Models\Invoice;
use 
App\Models\Utility;
use 
Illuminate\Http\Request;

class 
CreditNoteController extends Controller
{
    public function 
__construct()
    {
        
$this->middleware('auth');
    }

    public function 
index()
    {
        if(
\Auth::user()->can('manage credit note'))
        {
            
$invoices Invoice::where('created_by'\Auth::user()->creatorId())->get();

            return 
view('creditNote.index'compact('invoices'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }

    public function 
create($invoice_id)
    {
        if(
\Auth::user()->can('create credit note'))
        {

            
$invoiceDue Invoice::where('id'$invoice_id)->first();

            return 
view('creditNote.create'compact('invoiceDue''invoice_id'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }

    public function 
store(Request $request$invoice_id)
    {
        if(
\Auth::user()->can('create credit note'))
        {
            
$validator \Validator::make(
                
$request->all(), [
                                   
'amount' => 'required|numeric',
                                   
'date' => 'required',
                               ]
            );
            if(
$validator->fails())
            {
                
$messages $validator->getMessageBag();

                return 
redirect()->back()->with('error'$messages->first());
            }
            
$invoiceDue Invoice::where('id'$invoice_id)->first();
            if(
$request->amount $invoiceDue->getDue())
            {
                return 
redirect()->back()->with('error''Maximum ' \Auth::user()->priceFormat($invoiceDue->getDue()) . ' credit limit of this invoice.');
            }
            
$invoice Invoice::where('id'$invoice_id)->first();

            
$credit              = new CreditNote();
            
$credit->invoice     $invoice_id;
            
$credit->customer    $invoice->customer_id;
            
$credit->date        $request->date;
            
$credit->amount      $request->amount;
            
$credit->description $request->description;
            
$credit->save();

            
Utility::userBalance('customer'$invoice->customer_id$request->amount'debit');

            return 
redirect()->back()->with('success'__('Credit Note successfully created.'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }


    public function 
edit($invoice_id$creditNote_id)
    {
        if(
\Auth::user()->can('edit credit note'))
        {

            
$creditNote CreditNote::find($creditNote_id);

            return 
view('creditNote.edit'compact('creditNote'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }


    public function 
update(Request $request$invoice_id$creditNote_id)
    {

        if(
\Auth::user()->can('edit credit note'))
        {

            
$validator \Validator::make(
                
$request->all(), [
                                   
'amount' => 'required|numeric',
                                   
'date' => 'required',
                               ]
            );

            if(
$validator->fails())
            {
                
$messages $validator->getMessageBag();

                return 
redirect()->back()->with('error'$messages->first());
            }
            
$invoiceDue Invoice::where('id'$invoice_id)->first();

            if(
$request->amount $invoiceDue->getDue())
            {
                return 
redirect()->back()->with('error''Maximum ' \Auth::user()->priceFormat($invoiceDue->getDue()) . ' credit limit of this invoice.');
            }

            
$credit CreditNote::find($creditNote_id);
            
Utility::userBalance('customer'$invoiceDue->customer_id$credit->amount'credit');
            
$credit->date        $request->date;
            
$credit->amount      $request->amount;
            
$credit->description $request->description;
            
$credit->save();

            
Utility::userBalance('customer'$invoiceDue->customer_id$request->amount'debit');

            return 
redirect()->back()->with('success'__('Credit Note successfully updated.'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }


    public function 
destroy($invoice_id$creditNote_id)
    {
        if(
\Auth::user()->can('delete credit note'))
        {

            
$creditNote CreditNote::find($creditNote_id);
            
$creditNote->delete();

            
Utility::userBalance('customer'$creditNote->customer$creditNote->amount'credit');

            return 
redirect()->back()->with('success'__('Credit Note successfully deleted.'));

        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }

    public function 
customCreate()
    {
        if(
\Auth::user()->can('create credit note'))
        {

            
$invoices Invoice::where('created_by'\Auth::user()->creatorId())->get()->pluck('invoice_id''id');

            return 
view('creditNote.custom_create'compact('invoices'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }

    public function 
customStore(Request $request)
    {
        if(
\Auth::user()->can('create credit note'))
        {
            
$validator \Validator::make(
                
$request->all(), [
                                   
'invoice' => 'required|numeric',
                                   
'amount' => 'required|numeric',
                                   
'date' => 'required',
                               ]
            );
            if(
$validator->fails())
            {
                
$messages $validator->getMessageBag();

                return 
redirect()->back()->with('error'$messages->first());
            }
            
$invoice_id $request->invoice;
            
$invoiceDue Invoice::where('id'$invoice_id)->first();

            if(
$request->amount $invoiceDue->getDue())
            {
                return 
redirect()->back()->with('error''Maximum ' \Auth::user()->priceFormat($invoiceDue->getDue()) . ' credit limit of this invoice.');
            }
            
$invoice             Invoice::where('id'$invoice_id)->first();
            
$credit              = new CreditNote();
            
$credit->invoice     $invoice_id;
            
$credit->customer    $invoice->customer_id;
            
$credit->date        $request->date;
            
$credit->amount      $request->amount;
            
$credit->description $request->description;
            
$credit->save();

            
Utility::userBalance('customer'$invoice->customer_id$request->amount'debit');

            return 
redirect()->back()->with('success'__('Credit Note successfully created.'));
        }
        else
        {
            return 
redirect()->back()->with('error'__('Permission denied.'));
        }
    }

    public function 
getinvoice(Request $request)
    {
        
$invoice Invoice::where('id'$request->id)->first();

        echo 
json_encode($invoice->getDue());
    }

}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

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

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