Anons79 Mini Shell

Directory : /home/aplikasiposinfo/public_html/talent.gosepakat.id/app/Http/Controllers/Admin/
Upload File :
Current File : /home/aplikasiposinfo/public_html/talent.gosepakat.id/app/Http/Controllers/Admin/UserController.php

<?php

namespace App\Http\Controllers\Admin;

use App\Facades\DataTable;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Log;
use Illuminate\Validation\Rules;
use Inertia\Inertia;

class UserController extends Controller
{
    public function index()
    {
        $filters = str_replace(
            [
                'status:verified',
                'status:unverified',
                'roles:Administrator',
                'roles:Author',
                'roles:Moderator',
            ],
            [
                'email_verified_at:NOT NULL',
                'email_verified_at:NULL',
                'roles.name:Administrator',
                'roles.name:Author',
                'roles.name:Moderator',
            ],
            request()->query('filters') ?? []
        );
        $sort = str_replace(
            ['name', 'created_at'],
            ['name', 'created_at'],
            request()->query('col')
        );

        $result = DataTable::query(User::whereIn('role', ['admin', 'operator']))
            ->searchable(['nama', 'email', 'role'])
            ->applyFilters($filters)
            ->allowedFilters([
                'email_verified_at:NOT NULL',
                'email_verified_at:NULL',
                // 'roles.name:Administrator',
                // 'roles.name:Author',
                // 'roles.name:Moderator',
            ])
            ->applySort($sort)
            ->allowedSorts(['nama', 'email', 'created_at'])
            ->make()->toArray();

        return Inertia::render('Admin/Users/Index', [
            'datatable' => $result
        ]);

    }

    public function ajaxData($type, Request $request)
    {
        if ($type == 'provinces') {
            $data = DB::table('provinces')->orderBy('name', 'ASC')->get();
        } else if ($type == 'regencies') {
            $data = DB::table('regencies')->orderBy('name', 'ASC')->where('province_id', $request->province_id)->get();
        } else if ($type == 'districts') {
            $data = DB::table('districts')->orderBy('name', 'ASC')->where('regency_id', $request->regency_id)->get();
        } else if ($type == 'villages') {
            $data = DB::table('villages')->orderBy('name', 'ASC')->where('district_id', $request->district_id)->get();
        } else {
            $data = [];
        }

        return response()->json($data);
    }

    public function create()
    {
        return Inertia::render('Admin/Users/Create');
    }

    public function store(Request $request)
    {
        $request->validate([
            'nama' => 'required|string|max:255',
            'email' => 'required|string|lowercase|email|max:255|unique:' . User::class,
            'password' => ['required', 'confirmed', Rules\Password::defaults()],
        ]);

        $user = User::create([
            'nama' => $request->nama,
            'email' => $request->email,
            'password' => Hash::make($request->password),
            'role' => $request->role

        ]);

        $user->user_statuses()->create([
            'status' => 'active',
            'description' => 'menunggu verifikasi dokumen'
        ]);

        return redirect()->route('admin.user.index')->with('success', 'Berhasil menambah user ' . $user->nama);
    }

    public function edit($id)
    {
        $user = User::findOrFail($id);
        return Inertia::render('Admin/Users/Edit', compact('user'));
    }

    public function update(Request $request, $id)
    {
        $request->validate([
            'nama' => 'required|string|max:255',
            'email' => 'required|string|lowercase|email|max:255|unique:' . User::class . ',id,' . $id,

        ]);
        $user = User::findOrFail($id);
        $user->nama = $request->nama;
        $user->email = $request->email;
        $user->role = $request->role;

        if ($request->password != "") {
            $request->validate([
                'password' => ['required', Rules\Password::defaults()],
            ]);
            $user->password = Hash::make($request->password);
        }

        $user->save();




        return redirect()->route('admin.user.index')->with('success', 'Berhasil mengubah user ' . $user->nama);
    }

    public function destroy($id)
    {
        $user = User::findOrFail($id);
        DB::beginTransaction();
        try {

            $user->delete();


            DB::commit();
            return redirect()->route('admin.user.index')->with('success', 'Berhasil menghapus user ' . $user->nama);
        } catch (\Throwable $th) {
            //throw $th;
            DB::rollBack();
            Log::error($th);
            return redirect()->route('admin.user.index')->with('error', 'Gagal menghapus user ' . $user->nama);
        }
    }

}

Anons79 File Manager Version 1.0, Coded By Anons79
Email: [email protected]