<?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]