Files
musadaq-saas/app/modules_app/batches/finalize.php
2026-05-07 01:18:53 +03:00

65 lines
1.6 KiB
PHP

<?php
/**
* Finalize Batch Endpoint
* POST /v1/batches/finalize
*
* Marks a batch as ready for processing.
* Triggers background processing (or processes synchronously depending on setup).
*/
declare(strict_types=1);
use App\Core\Database;
use App\Middleware\AuthMiddleware;
use App\Core\Security;
$decoded = AuthMiddleware::check();
$tenantId = $decoded['tenant_id'];
$userId = $decoded['user_id'];
$data = Security::sanitize(input());
$batchId = $data['batch_id'] ?? null;
if (!$batchId) {
json_error('معرّف الدفعة مطلوب', 422);
}
$db = Database::getInstance();
// 1. Verify batch
$stmt = $db->prepare("
SELECT id, tenant_id, status, total_images
FROM invoice_batches
WHERE id = ? AND uploaded_by = ?
");
$stmt->execute([$batchId, $userId]);
$batch = $stmt->fetch();
if (!$batch || ($decoded['role'] !== 'super_admin' && $batch['tenant_id'] !== $tenantId)) {
json_error('الدفعة غير موجودة', 404);
}
if ($batch['status'] !== 'uploading') {
json_error('تم إنهاء هذه الدفعة مسبقاً', 400);
}
if ($batch['total_images'] == 0) {
json_error('لا يمكن إنهاء دفعة فارغة', 400);
}
// 2. Mark as done since AI processing is now synchronous
$stmt = $db->prepare("
UPDATE invoice_batches
SET status = 'done', completed_at = NOW(), updated_at = NOW()
WHERE id = ?
");
$stmt->execute([$batchId]);
json_success([
'batch_id' => $batchId,
'status' => 'done',
'total_images' => $batch['total_images']
], 'تم رفع ومعالجة الدفعة بنجاح');