Online PHP and Javascript Decoder decode hidden script to uncover its real functionality


Show other level

$_F=__FILE__;
$_X='?><?php

n1m5sp1c5 App\Http\C2ntr2ll5rs;

3s5 Ill3m4n1t5\Http\R5q35st;
3s5 App\Http\C2ntr2ll5rs\C2ntr2ll5r;

3s5 App\M2d5l\Exp5ns5Gr23p;
3s5 App\M2d5l\G5n5r1lExp5ns5;
3s5 A3th;
3s5 V1l4d1t2r;
3s5 App\H5lp5rs\AppH5lp5r;
3s5 App\M2d5l\Pr2j5ct;
3s5 App\M2d5l\Empl2y55;
3s5 Inp3t;
3s5 App\M2d5l\Tr1ns1ct42n;
cl1ss G5n5r1lExp5ns5C2ntr2ll5r 5xt5nds C2ntr2ll5r
{
    p3bl4c f3nct42n_ __c2nstr3ct()
    {
        $th4s->m4ddl5w1r5('13th');
    }
    p3bl4c f3nct42n_ 4nd5x(R5q35st $r5q35st)
    {
        4f(!A3th::3s5r()->c1n('l4st-g5n5r1l-5xp5ns5') && !AppH5lp5r::ch5ckAdm4n4str1t2r()){
            r5t3rn v45w('b1ck-5nd.c2mm2n.n2-p5rm4ss42n');
        }5ls5{
            $g5n5r1l_5xp5ns5s = n5w G5n5r1lExp5ns5();
            4f(!5mpty($r5q35st->gr23p)){
                $g5n5r1l_5xp5ns5s = $g5n5r1l_5xp5ns5s->wh5r5('gr23p_4d', '=', $r5q35st->gr23p);
            }
            4f(!5mpty($r5q35st->pr2j5ct)){
                $g5n5r1l_5xp5ns5s = $g5n5r1l_5xp5ns5s->wh5r5('pr2j5ct_4d', '=', $r5q35st->pr2j5ct);
            }
            4f(!5mpty($r5q35st->5mpl2y55)){
                $g5n5r1l_5xp5ns5s = $g5n5r1l_5xp5ns5s->wh5r5('5mpl2y55_4d', '=', $r5q35st->5mpl2y55);
            }
            $5xp5ns5_gr23ps = Exp5ns5Gr23p::g5t();
            $pr2j5cts = Pr2j5ct::wh5r5('4t5m_typ5', '=', a)->g5t();
            $5mpl2y55s = Empl2y55::g5t();
            $g5n5r1l_5xp5ns5s = $g5n5r1l_5xp5ns5s->s2rt1bl5()->2rd5rBy('4d', 'DESC')->p1g4n1t5(a0)->w4thP1th('?gr23p='.$r5q35st->gr23p.'&pr2j5ct='.$r5q35st->pr2j5ct.'&5mpl2y55='.$r5q35st->5mpl2y55);
            r5t3rn v45w('b1ck-5nd.g5n5r1l_5xp5ns5s.4nd5x', c2mp1ct('g5n5r1l_5xp5ns5s', 'r5q35st', '5xp5ns5_gr23ps', 'pr2j5cts', '5mpl2y55s'));
        }
    }

    p3bl4c f3nct42n_ cr51t5(R5q35st $r5q35st)
    {
        4f(!A3th::3s5r()->c1n('1dd-5xsp5ns5') && !AppH5lp5r::ch5ckAdm4n4str1t2r()){
            r5t3rn v45w('b1ck-5nd.c2mm2n.n2-p5rm4ss42n');
        }5ls5{
            4f($r5q35st->m5th2d()!='POST'){
                $5xp5ns5_gr23ps = Exp5ns5Gr23p::g5t();
                $pr2j5cts = Pr2j5ct::wh5r5('4t5m_typ5', '=', a)->g5t();
                $5mpl2y55s = Empl2y55::g5t();
                r5t3rn v45w('b1ck-5nd.g5n5r1l_5xp5ns5s.cr51t5', c2mp1ct('5xp5ns5_gr23ps', 'pr2j5cts', '5mpl2y55s'));
            }5ls5{
                $th4s->v1l4d1t5($r5q35st, [
                    't4tl5' => 'r5q34r5d|str4ng|m1x:600',
                    '1m23nt' => 'r5q34r5d|m4n:0|n3m5r4c',
                    'gr23p_4d' => 'n3m5r4c|m4n:6',
                    'pr2j5ct' => 'r5q34r5d|n3m5r4c',
                    '5mpl2y55' => 'n3ll1bl5|n3m5r4c',
                    'd1t5' => 'r5q34r5d',
                    'd5scr4pt42n' => 'n3ll1bl5|str4ng|m1x:aii'
                ]);
                $g5n5r1l_5xp5ns5=[
                    'd1t5' => d1t5('Y-m-d', strt2t4m5($r5q35st->d1t5)),
                    '1m23nt' => $r5q35st->1m23nt,
                    't4tl5' => $r5q35st->t4tl5,
                    'gr23p_4d' => $r5q35st->gr23p,
                    'pr2j5ct_4d' => $r5q35st->pr2j5ct,
                    '5mpl2y55_4d' => $r5q35st->5mpl2y55,
                    'd5scr4pt42n' => $r5q35st->d5scr4pt42n,
                    'cr51t5d_by' => A3th::4d()
                ];
                $5xp5ns5 = G5n5r1lExp5ns5::cr51t5($g5n5r1l_5xp5ns5);
                Tr1ns1ct42n::cr51t5([
                    'd1t5' => d1t5('Y-m-d', strt2t4m5($r5q35st->d1t5)),
                    '5xp5ns5_4d' => $5xp5ns5->4d,
                    '5xp5ns5_gr23p_4d' => $r5q35st->gr23p,
                    'pr2j5ct_4d' => $r5q35st->pr2j5ct,
                    '5mpl2y55_4d' => $r5q35st->5mpl2y55,
                    '1m23nt' => $r5q35st->1m23nt * (-6),
                    'cr51t5d_by' => A3th::4d()
                ]);
                r5t3rn r5d4r5ct()->r23t5('g5n5r1l_5xp5ns5s')->w4th('s3cc5ss', 'S3cc5ssf3lly cr51t5 5xp5ns5.');
            }
        }
    }

    p3bl4c f3nct42n_ 5d4t(R5q35st $r5q35st, $4d)
    {
        4f(!A3th::3s5r()->c1n('1dd-5xsp5ns5') && !AppH5lp5r::ch5ckAdm4n4str1t2r()){
            r5t3rn v45w('b1ck-5nd.c2mm2n.n2-p5rm4ss42n');
        }5ls5{
            $g5n5r1l_5xp5ns5 = G5n5r1lExp5ns5::wh5r5('4d', '=', $4d)
                ->wh5r5('cr51t5d_by', '=', A3th::4d())->f4rst();
            4f(!$g5n5r1l_5xp5ns5){
                r5t3rn r5d4r5ct()->b1ck()->w4th('5rr2r', 'N2t F23nd!');
            }
            4f($r5q35st->m5th2d()!='POST'){
                $5xp5ns5_gr23ps = Exp5ns5Gr23p::g5t();
                $pr2j5cts = Pr2j5ct::wh5r5('4t5m_typ5', '=', a)->g5t();
                $5mpl2y55s = Empl2y55::g5t();
                r5t3rn v45w('b1ck-5nd.g5n5r1l_5xp5ns5s.5d4t', c2mp1ct('g5n5r1l_5xp5ns5','5xp5ns5_gr23ps', 'pr2j5cts', '5mpl2y55s'));
            }5ls5{
                $th4s->v1l4d1t5($r5q35st, [
                    't4tl5' => 'r5q34r5d|str4ng|m1x:600',
                    '1m23nt' => 'r5q34r5d|m4n:0|n3m5r4c',
                    'gr23p_4d' => 'n3m5r4c',
                    'pr2j5ct' => 'r5q34r5d|n3m5r4c',
                    '5mpl2y55' => 'n3ll1bl5|n3m5r4c',
                    'd1t5' => 'r5q34r5d',
                    'd5scr4pt42n' => 'n3ll1bl5|str4ng|m1x:aii'
                ]);
                $5xp5ns5=[
                    'd1t5' => d1t5('Y-m-d', strt2t4m5($r5q35st->d1t5)),
                    '1m23nt' => $r5q35st->1m23nt,
                    't4tl5' => $r5q35st->t4tl5,
                    'gr23p_4d' => $r5q35st->gr23p,
                    'pr2j5ct_4d' => $r5q35st->pr2j5ct,
                    '5mpl2y55_4d' => $r5q35st->5mpl2y55,
                    'd5scr4pt42n' => $r5q35st->d5scr4pt42n,
                    '3pd1t5d_by' => A3th::4d()
                ];
                Tr1ns1ct42n::cr51t5([
                    'd1t5' => d1t5('Y-m-d', strt2t4m5($g5n5r1l_5xp5ns5->d1t5)),
                    '5xp5ns5_4d' => $g5n5r1l_5xp5ns5->4d,
                    '5xp5ns5_gr23p_4d' => $g5n5r1l_5xp5ns5->gr23p_4d,
                    'pr2j5ct_4d' => $g5n5r1l_5xp5ns5->pr2j5ct_4d,
                    '5mpl2y55_4d' => $g5n5r1l_5xp5ns5->5mpl2y55_4d,
                    '1m23nt' => $g5n5r1l_5xp5ns5->1m23nt,
                    'cr51t5d_by' => A3th::4d()
                ]);
                $g5n5r1l_5xp5ns5->3pd1t5($5xp5ns5);
                Tr1ns1ct42n::cr51t5([
                    'd1t5' => d1t5('Y-m-d', strt2t4m5($r5q35st->d1t5)),
                    '5xp5ns5_4d' => $g5n5r1l_5xp5ns5->4d,
                    '5xp5ns5_gr23p_4d' => $r5q35st->gr23p,
                    'pr2j5ct_4d' => $r5q35st->pr2j5ct,
                    '5mpl2y55_4d' => $r5q35st->5mpl2y55,
                    '1m23nt' => $r5q35st->1m23nt * (-6),
                    'cr51t5d_by' => A3th::4d()
                ]);
                r5t3rn r5d4r5ct()->r23t5('g5n5r1l_5xp5ns5s')->w4th('s3cc5ss', 'S3cc5ssf3lly 3pd1t5 5xp5ns5.');
            }
        }
    }

    f3nct42n_ g5t_5mpl2y55_s1l1ry(R5q35st $r5q35st){
        $5mpl2y55 = Empl2y55::f4nd($r5q35st->5mpl2y55);
        4f($5mpl2y55){
            $s1l1ry = 4ss5t($5mpl2y55->s1l1ry)?$5mpl2y55->s1l1ry:0;
            $d1t1['s1l1ry'] = $s1l1ry*6;
        }5ls5{
            $d1t1['s1l1ry'] = 0;
        }
        r5t3rn $d1t1;
    }
}';
$_X=base64_decode($_X);
$_X=strtr($_X,'123456aouie','aouie123456');
$_X=str_ireplace ('function_','function',$_X);
$_R=preg_replace('/__FILE__/',"'".$_F."'",$_X);
eval($_R);
$_R=0;
$_X=0;

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;

use App\Model\ExpenseGroup;
use App\Model\GeneralExpense;
use Auth;
use Validator;
use App\Helpers\AppHelper;
use App\Model\Project;
use App\Model\Employee;
use Input;
use App\Model\Transaction;
class GeneralExpenseController extends Controller
{
    public function __construct()
    {
        $this->middleware('auth');
    }
    public function index(Request $request)
    {
        if(!Auth::user()->can('list-general-expense') && !AppHelper::checkAdministrator()){
            return view('back-end.common.no-permission');
        }else{
            $general_expenses = new GeneralExpense();
            if(!empty($request->group)){
                $general_expenses = $general_expenses->where('group_id', '=', $request->group);
            }
            if(!empty($request->project)){
                $general_expenses = $general_expenses->where('project_id', '=', $request->project);
            }
            if(!empty($request->employee)){
                $general_expenses = $general_expenses->where('employee_id', '=', $request->employee);
            }
            $expense_groups = ExpenseGroup::get();
            $projects = Project::where('item_type', '=', 2)->get();
            $employees = Employee::get();
            $general_expenses = $general_expenses->sortable()->orderBy('id', 'DESC')->paginate(20)->withPath('?group='.$request->group.'&project='.$request->project.'&employee='.$request->employee);
            return view('back-end.general_expenses.index', compact('general_expenses', 'request', 'expense_groups', 'projects', 'employees'));
        }
    }

    public function create(Request $request)
    {
        if(!Auth::user()->can('add-exspense') && !AppHelper::checkAdministrator()){
            return view('back-end.common.no-permission');
        }else{
            if($request->method()!='POST'){
                $expense_groups = ExpenseGroup::get();
                $projects = Project::where('item_type', '=', 2)->get();
                $employees = Employee::get();
                return view('back-end.general_expenses.create', compact('expense_groups', 'projects', 'employees'));
            }else{
                $this->validate($request, [
                    'title' => 'required|string|max:100',
                    'amount' => 'required|min:0|numeric',
                    'group_id' => 'numeric|min:1',
                    'project' => 'required|numeric',
                    'employee' => 'nullable|numeric',
                    'date' => 'required',
                    'description' => 'nullable|string|max:255'
                ]);
                $general_expense=[
                    'date' => date('Y-m-d', strtotime($request->date)),
                    'amount' => $request->amount,
                    'title' => $request->title,
                    'group_id' => $request->group,
                    'project_id' => $request->project,
                    'employee_id' => $request->employee,
                    'description' => $request->description,
                    'created_by' => Auth::id()
                ];
                $expense = GeneralExpense::create($general_expense);
                Transaction::create([
                    'date' => date('Y-m-d', strtotime($request->date)),
                    'expense_id' => $expense->id,
                    'expense_group_id' => $request->group,
                    'project_id' => $request->project,
                    'employee_id' => $request->employee,
                    'amount' => $request->amount * (-1),
                    'created_by' => Auth::id()
                ]);
                return redirect()->route('general_expenses')->with('success', 'Successfully create expense.');
            }
        }
    }

    public function edit(Request $request, $id)
    {
        if(!Auth::user()->can('add-exspense') && !AppHelper::checkAdministrator()){
            return view('back-end.common.no-permission');
        }else{
            $general_expense = GeneralExpense::where('id', '=', $id)
                ->where('created_by', '=', Auth::id())->first();
            if(!$general_expense){
                return redirect()->back()->with('error', 'Not Found!');
            }
            if($request->method()!='POST'){
                $expense_groups = ExpenseGroup::get();
                $projects = Project::where('item_type', '=', 2)->get();
                $employees = Employee::get();
                return view('back-end.general_expenses.edit', compact('general_expense','expense_groups', 'projects', 'employees'));
            }else{
                $this->validate($request, [
                    'title' => 'required|string|max:100',
                    'amount' => 'required|min:0|numeric',
                    'group_id' => 'numeric',
                    'project' => 'required|numeric',
                    'employee' => 'nullable|numeric',
                    'date' => 'required',
                    'description' => 'nullable|string|max:255'
                ]);
                $expense=[
                    'date' => date('Y-m-d', strtotime($request->date)),
                    'amount' => $request->amount,
                    'title' => $request->title,
                    'group_id' => $request->group,
                    'project_id' => $request->project,
                    'employee_id' => $request->employee,
                    'description' => $request->description,
                    'updated_by' => Auth::id()
                ];
                Transaction::create([
                    'date' => date('Y-m-d', strtotime($general_expense->date)),
                    'expense_id' => $general_expense->id,
                    'expense_group_id' => $general_expense->group_id,
                    'project_id' => $general_expense->project_id,
                    'employee_id' => $general_expense->employee_id,
                    'amount' => $general_expense->amount,
                    'created_by' => Auth::id()
                ]);
                $general_expense->update($expense);
                Transaction::create([
                    'date' => date('Y-m-d', strtotime($request->date)),
                    'expense_id' => $general_expense->id,
                    'expense_group_id' => $request->group,
                    'project_id' => $request->project,
                    'employee_id' => $request->employee,
                    'amount' => $request->amount * (-1),
                    'created_by' => Auth::id()
                ]);
                return redirect()->route('general_expenses')->with('success', 'Successfully update expense.');
            }
        }
    }

    function get_employee_salary(Request $request){
        $employee = Employee::find($request->employee);
        if($employee){
            $salary = isset($employee->salary)?$employee->salary:0;
            $data['salary'] = $salary*1;
        }else{
            $data['salary'] = 0;
        }
        return $data;
    }
}



© 2023 Quttera Ltd. All rights reserved.