Anons79 Mini Shell

Directory : /home/aplikasiposinfo/www/dispora.aplikasipos.info/app/Http/Controllers/
Upload File :
Current File : /home/aplikasiposinfo/www/dispora.aplikasipos.info/app/Http/Controllers/DocumentPhotoController.php

<?php

namespace App\Http\Controllers;

use App\Models\document_photo;
use Illuminate\Contracts\Encryption\DecryptException;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Crypt;
use Illuminate\Support\Facades\File;

class DocumentPhotoController extends Controller
{
    public function index()
    {
        $data['document'] = document_photo::get();
        return view('document_photo.index')->with($data);
    }
    public function store(Request $request)
    {
        $photo = $request->file('photo');
        $extensi = $photo->extension();
        $size = $photo->getSize();
        $photoSizeKB = ceil($size / 1024);
        $nama_asli = $photo->getClientOriginalName();
        $request->validate([

            'deskripsi' => 'required',
            'photo' => 'required|mimes:jpg,jpeg,png,gif,svg',
        ], [
            'photo.mimes' => 'Tolong masukan photo dengan format(jpg,jpeg,png,gif,svg)!',
        ]);

        $data = [
            'name' => $nama_asli,
            'deskripsi' => $request->deskripsi,
            'admin_id' => auth()->user()->id,
            'tanggal' => now(),
            'jumlah_download' => 0,
            'ekstensi' => $extensi,
            'ukuran' => $photoSizeKB,
            'jenis' => 2
        ];


        $check = document_photo::where('name', $nama_asli)->first();
        $photo->move(public_path('document_photos'), $nama_asli);
        if ($check == null) {
            document_photo::create($data);
            return redirect()->route('document_photo')->with('success', 'Data berhasil ditambahkan');
        } else {
            return redirect()->route('document_photo')->with('error', 'File sudah pernah diupload !');
        }
    }
    public function update(Request $request, string $id)
    {
        $decryptedId = Crypt::decryptString($id);

        $request->validate([

            'deskripsi' => 'required',
            'photo' => 'nullable|mimes:jpg,jpeg,png,gif,svg',
        ], [
            'photo.mimes' => 'Tolong masukan photo dengan format(jpg,jpeg,png,gif,svg)!',
        ]);
        if ($request->hasFile('photo')) {
            $photo = $request->file('photo');
            $extensi = $photo->extension();
            $size = $photo->getSize();
            $photoSizeKB = ceil($size / 1024);
            $nama_asli = $photo->getClientOriginalName();

            $data = [
                'name' => $nama_asli,
                'deskripsi' => $request->deskripsi,
                'admin_id' => auth()->user()->id,
                'tanggal' => now(),
                'jumlah_download' => 0,
                'ekstensi' => $extensi,
                'ukuran' => $photoSizeKB,
                'jenis' => 2
            ];
            $check = document_photo::where('name', $nama_asli)->where('id', '<>', $decryptedId)->first();

            if ($check == null) {

                $getphoto = document_photo::where('id', $decryptedId)->first();
                $oldphoto = $getphoto->name;
                File::delete(public_path('document_photos') . "/" . $oldphoto);
                $photo->move(public_path('document_photos'), $nama_asli);
                document_photo::where('id', $decryptedId)->update($data);
                return redirect()->route('document_photo')->with('success', 'Data berhasil diubah');
            } else {
                return redirect()->route('document_photo')->with('error', 'Photo sudah pernah diupload !');
            }
        } else {
            $data = ['deskripsi' => $request->deskripsi];
            document_photo::where('id', $decryptedId)->update($data);
            return redirect()->route('document_photo')->with('success', 'Data berhasil diubah');
        }
    }
    public function destroy(string $id)
    {
        try {
            $decryptedId = Crypt::decryptString($id);
            $document_photo = document_photo::where('id', $decryptedId);
            $file = $document_photo->first();
            File::delete(public_path('document_photos') . "/" . $file->name);
            $document_photo->delete();
            return redirect()->route('document_photo')->with('delete', 'Data successfully deleted');
        } catch (DecryptException $e) {
            return redirect()->back()->with('error', 'Invalid ID');
        }
    }
}

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