fix(dokumen_jaminan): tambahkan validasi sebelum menghapus dokumen jaminan

- Memastikan hanya administrator yang dapat menghapus dokumen jaminan.
- Menambahkan pengecekan untuk memastikan dokumen jaminan ada sebelum dihapus.
- Menambahkan validasi untuk mencegah penghapusan dokumen jaminan yang terkait dengan permohonan aktif.
- Menggunakan transaksi database untuk menjaga konsistensi data saat menghapus dokumen dan detailnya.
This commit is contained in:
Daeng Deni Mardaeni
2025-03-03 15:44:00 +07:00
parent 3c5e4a7df6
commit 97109250c9

View File

@@ -385,16 +385,37 @@
) )
{ {
try { try {
// Periksa apakah pengguna adalah admin
if (!auth()->user()->hasRole('administrator')) {
return response()->json(['success' => false, 'message' => 'Hanya administrator yang dapat menghapus dokumen jaminan'], 403);
}
$jaminan = DokumenJaminan::find($jaminan_id); $jaminan = DokumenJaminan::find($jaminan_id);
if (!$jaminan) {
return response()->json(['success' => false, 'message' => 'Dokumen Jaminan tidak ditemukan'], 404);
}
// Periksa apakah dokumen jaminan terkait dengan permohonan aktif
if ($jaminan->permohonan()->exists()) {
return response()->json(['success' => false, 'message' => 'Tidak dapat menghapus dokumen jaminan yang terkait dengan permohonan aktif'], 400);
}
DB::beginTransaction();
$details = DetailDokumenJaminan::where('dokumen_jaminan_id', $jaminan->id)->get(); $details = DetailDokumenJaminan::where('dokumen_jaminan_id', $jaminan->id)->get();
foreach ($details as $detail) { foreach ($details as $detail) {
Storage::delete('public/' . $detail->dokumen_jaminan); Storage::delete('public/' . $detail->dokumen_jaminan);
$detail->delete(); $detail->delete();
} }
$jaminan->delete(); $jaminan->delete();
echo json_encode(['success' => true, 'message' => 'Dokumen Jaminan deleted successfully']);
DB::commit();
return response()->json(['success' => true, 'message' => 'Dokumen Jaminan berhasil dihapus']);
} catch (Exception $e) { } catch (Exception $e) {
echo json_encode(['success' => false, 'message' => 'Failed to delete Dokumen Jaminan']); DB::rollBack();
return response()->json(['success' => false, 'message' => 'Gagal menghapus Dokumen Jaminan: ' . $e->getMessage()], 500);
} }
} }