RegradeOCRSubmission.php 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. namespace App\Jobs;
  3. use App\Models\OCRRecord;
  4. use App\Services\IntelligentGradingService;
  5. use Illuminate\Bus\Queueable;
  6. use Illuminate\Contracts\Queue\ShouldQueue;
  7. use Illuminate\Foundation\Bus\Dispatchable;
  8. use Illuminate\Queue\InteractsWithQueue;
  9. use Illuminate\Queue\SerializesModels;
  10. use Illuminate\Support\Facades\Log;
  11. class RegradeOCRSubmission implements ShouldQueue
  12. {
  13. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  14. public int $ocrRecordId;
  15. public int $maxAttempts = 3;
  16. public function __construct(int $ocrRecordId)
  17. {
  18. $this->ocrRecordId = $ocrRecordId;
  19. }
  20. public function handle(IntelligentGradingService $gradingService): void
  21. {
  22. $ocrRecord = OCRRecord::find($this->ocrRecordId);
  23. if (!$ocrRecord) {
  24. Log::error('OCR记录不存在,无法重新判分', ['ocr_record_id' => $this->ocrRecordId]);
  25. return;
  26. }
  27. try {
  28. Log::info('开始重新判分任务', ['ocr_record_id' => $this->ocrRecordId]);
  29. // 清除之前的AI判分结果
  30. \App\Models\OCRQuestionResult::where('ocr_record_id', $this->ocrRecordId)
  31. ->update([
  32. 'ai_score' => null,
  33. 'ai_feedback' => null,
  34. 'ai_confidence' => null,
  35. 'ai_analyzed_at' => null,
  36. ]);
  37. // 重新调用判分服务
  38. $results = $gradingService->gradeSubmission($this->ocrRecordId);
  39. Log::info('重新判分完成', [
  40. 'ocr_record_id' => $this->ocrRecordId,
  41. 'total_score' => $results['total_score'] ?? 0,
  42. ]);
  43. } catch (\Exception $e) {
  44. Log::error('重新判分失败', [
  45. 'ocr_record_id' => $this->ocrRecordId,
  46. 'error' => $e->getMessage(),
  47. ]);
  48. throw $e;
  49. }
  50. }
  51. }