Total Complexity | 10 |
Total Lines | 51 |
Duplicated Lines | 0 % |
Changes | 0 |
1 | <?php |
||
16 | class Judger extends Curl |
||
17 | { |
||
18 | public $data=null; |
||
19 | private $judger=[]; |
||
20 | public $ret=[]; |
||
21 | |||
22 | /** |
||
23 | * Initial |
||
24 | * |
||
25 | * @return Response |
||
|
|||
26 | */ |
||
27 | public function __construct() |
||
28 | { |
||
29 | $submissionModel=new SubmissionModel(); |
||
30 | |||
31 | $result=$submissionModel->getWaitingSubmission(); |
||
32 | |||
33 | $submissionCount = count($result); |
||
34 | |||
35 | Log::channel('babel_judge_sync')->info("Currently $submissionCount submission(s) awaiting", [$result]); |
||
36 | |||
37 | foreach ($result as $row) { |
||
38 | $ocode=$row["ocode"]; |
||
39 | try { |
||
40 | if (!isset($this->judger[$ocode]) || is_null($this->judger[$ocode])) { |
||
41 | $this->judger[$ocode]=self::create($ocode); |
||
42 | } |
||
43 | $this->judger[$ocode]->judge($row); |
||
44 | } catch (Throwable $e) { |
||
45 | Log::channel('babel_judge_sync')->alert("Exception Occurs While Processing $ocode's Submission {$row['sid']}\n".$e->getMessage()."\nAt ".$e->getFile().":".$e->getLine()); |
||
46 | } catch (Exception $e) { |
||
47 | Log::channel('babel_judge_sync')->alert("Exception Occurs While Processing $ocode's Submission {$row['sid']}\n".$e->getMessage()."\nAt ".$e->getFile().":".$e->getLine()); |
||
48 | } |
||
49 | } |
||
50 | } |
||
51 | |||
52 | public static function create($ocode) |
||
67 | } |
||
68 | } |
||
70 |