ai-refactor(flow): 调整抽象流程节点实现和依赖路径
- 修改 AbstractProcessNode 中 ProcessContext 的命名空间引用为 app\flow\context\ProcessContext - 引入 app\flow\vo\CanHandleResult 用于节点处理结果表示 - 更新前置策略执行后对成功状态的判断,改为调用 isSuccess() 方法 - 增加日志记录细节,便于调试策略执行中断时的错误信息 - 优化代码注释,提升代码可读性和维护性
This commit is contained in:
@@ -3,9 +3,11 @@
|
||||
namespace app\flow\nodes;
|
||||
|
||||
use app\config\Config;
|
||||
use app\flow\DbOperationType;
|
||||
use app\flow\ProcessContext;
|
||||
use app\flow\VoiceMessage;
|
||||
use app\flow\enum\DbOperationType;
|
||||
use app\flow\context\ProcessContext;
|
||||
use app\flow\enum\VoiceMessage;
|
||||
use app\flow\vo\CanHandleResult;
|
||||
use app\flow\vo\StorageStatus;
|
||||
use app\utils\Logger;
|
||||
|
||||
/**
|
||||
@@ -35,38 +37,38 @@ class StorageInNode extends AbstractProcessNode
|
||||
* 判断当前节点是否能处理该步骤
|
||||
* 双读卡器模式:只在非单读卡器模式下生效
|
||||
*/
|
||||
public function canHandle(ProcessContext $context): bool
|
||||
public function canHandle(ProcessContext $context): CanHandleResult
|
||||
{
|
||||
$config = Config::getInstance();
|
||||
$singleReaderMode = $config->storageSingleReader;
|
||||
|
||||
// 单读卡器模式不处理,由 StorageNode 统一处理
|
||||
if ($singleReaderMode) {
|
||||
return false;
|
||||
return CanHandleResult::no();
|
||||
}
|
||||
|
||||
// 读卡器不是内镜放入类型,不处理
|
||||
if (!$this->isMatchReaderType($context)) {
|
||||
return false;
|
||||
return CanHandleResult::no();
|
||||
}
|
||||
|
||||
// 获取内镜当前存储状态
|
||||
$isInStorage = $context->isInStorage ?? false;
|
||||
$isInStorage = $context->getStorage()->isInStorage;
|
||||
|
||||
// 如果内镜已在库中,则当前应该是出库操作,不处理
|
||||
if ($isInStorage) {
|
||||
Logger::debug('[StorageInNode] 内镜已在库中,转由出库节点处理');
|
||||
return false;
|
||||
return CanHandleResult::no();
|
||||
}
|
||||
|
||||
// 检查前置步骤要求
|
||||
$validSteps = ['', '结束', '内镜取出', '测漏正常', '测漏异常'];
|
||||
if (!in_array($context->currentStep, $validSteps)) {
|
||||
Logger::debug('[StorageInNode] 当前步骤 {} 不符合入库条件', [$context->currentStep]);
|
||||
return false;
|
||||
if (!in_array($context->getCurrentStep(), $validSteps)) {
|
||||
Logger::debug('[StorageInNode] 当前步骤 {} 不符合入库条件', [$context->getCurrentStep()]);
|
||||
return CanHandleResult::no();
|
||||
}
|
||||
|
||||
return true;
|
||||
return CanHandleResult::yes();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -74,23 +76,15 @@ class StorageInNode extends AbstractProcessNode
|
||||
*/
|
||||
protected function doHandle(ProcessContext $context): ProcessContext
|
||||
{
|
||||
// 设置流程类型为存储
|
||||
$context->processType = '存储';
|
||||
Logger::debug('[StorageInNode] 内镜入库成功 endoscope={}', [$context->getEndoscope()->name]);
|
||||
|
||||
// 更新步骤
|
||||
$context->currentStep = self::getName();
|
||||
|
||||
// 标记入库状态
|
||||
$context->isInStorage = true;
|
||||
$context->storageInTime = date('Y-m-d H:i:s');
|
||||
|
||||
// 设置数据库操作
|
||||
$context->needDatabaseOperation = true;
|
||||
$context->dbOperation = DbOperationType::INSERT;
|
||||
$context->needWebSocketNotify = true;
|
||||
|
||||
Logger::debug('[StorageInNode] 内镜入库成功 endoscope={}', [$context->endoscopeName]);
|
||||
|
||||
return $context;
|
||||
return $context->builder()
|
||||
->withProcessType('存储')
|
||||
->withCurrentStep(self::getName())
|
||||
->withStorage(StorageStatus::inStorage(date('Y-m-d H:i:s')))
|
||||
->needDatabaseOperation()
|
||||
->dbOperation(DbOperationType::INSERT)
|
||||
->needWebSocketNotify()
|
||||
->build();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user