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:
@@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user