feat: 实现TCP Server
This commit is contained in:
@@ -0,0 +1,107 @@
|
||||
<?php
|
||||
|
||||
namespace app\flow\nodes;
|
||||
|
||||
use app\config\Config;
|
||||
use app\flow\DbOperationType;
|
||||
use app\flow\ProcessContext;
|
||||
use app\flow\VoiceMessage;
|
||||
use app\utils\Logger;
|
||||
|
||||
/**
|
||||
* 存储节点
|
||||
* 统一处理内镜存储的入库和出库操作
|
||||
*
|
||||
* 单读卡器模式:通过配置控制,一个读卡器交替执行入库/出库
|
||||
* 双读卡器模式:分别使用"内镜放入"和"内镜取出"两个读卡器
|
||||
*/
|
||||
class StorageNode extends AbstractProcessNode
|
||||
{
|
||||
/**
|
||||
* 获取节点名称
|
||||
*/
|
||||
public static function getName(): string
|
||||
{
|
||||
return '存储';
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取节点编码
|
||||
*/
|
||||
public function getCode(): string
|
||||
{
|
||||
return '存储';
|
||||
}
|
||||
|
||||
/**
|
||||
* 判断当前节点是否能处理该步骤
|
||||
*
|
||||
* 单读卡器模式:读卡器类型是'内镜放入'或'内镜取出',根据 isInStorage 状态判断执行入库还是出库
|
||||
*/
|
||||
public function canHandle(ProcessContext $context): bool
|
||||
{
|
||||
$config = Config::getInstance();
|
||||
$singleReaderMode = $config->storageSingleReader;
|
||||
|
||||
// 非单读卡器模式不处理
|
||||
if (!$singleReaderMode) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// 读卡器类型必须是'内镜放入'或'内镜取出'
|
||||
if (!in_array($context->readerType, ['内镜放入', '内镜取出'])) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$isInStorage = $context->isInStorage ?? false;
|
||||
|
||||
if ($isInStorage) {
|
||||
// 内镜已在库中,执行出库
|
||||
$validSteps = ['内镜放入', '结束'];
|
||||
if (!in_array($context->currentStep, $validSteps)) {
|
||||
Logger::debug('[StorageNode] 当前步骤 {} 不符合出库条件', [$context->currentStep]);
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
// 内镜不在库中,执行入库
|
||||
$validSteps = ['', '结束', '内镜取出', '测漏正常', '测漏异常'];
|
||||
if (!in_array($context->currentStep, $validSteps)) {
|
||||
Logger::debug('[StorageNode] 当前步骤 {} 不符合入库条件', [$context->currentStep]);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 具体处理逻辑
|
||||
* 根据 isInStorage 状态判断执行入库还是出库
|
||||
*/
|
||||
protected function doHandle(ProcessContext $context): ProcessContext
|
||||
{
|
||||
// 设置流程类型为存储
|
||||
$context->processType = '存储';
|
||||
|
||||
// 根据当前状态判断执行入库还是出库(canHandle 已经验证过状态)
|
||||
if (!$context->isInStorage) {
|
||||
// 入库操作
|
||||
$context->currentStep = '内镜放入';
|
||||
$context->isInStorage = true;
|
||||
$context->storageInTime = date('Y-m-d H:i:s');
|
||||
Logger::debug('[StorageNode] 内镜入库成功 endoscope={}', [$context->endoscopeName]);
|
||||
} else {
|
||||
// 出库操作
|
||||
$context->currentStep = '内镜取出';
|
||||
$context->isInStorage = false;
|
||||
Logger::debug('[StorageNode] 内镜出库成功 endoscope={}', [$context->endoscopeName]);
|
||||
}
|
||||
|
||||
// 设置数据库操作
|
||||
$context->needDatabaseOperation = true;
|
||||
$context->dbOperation = DbOperationType::INSERT;
|
||||
$context->needWebSocketNotify = true;
|
||||
|
||||
return $context;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user