addClassPaths('Mylog'); } public function createDTO(array $formDatas): MylogDTO { return new MylogDTO($formDatas); } public function getFormService(): MylogForm { if ($this->_form === null) { $this->_form = new MylogForm(); $this->_form->setAttributes([ 'pk_field' => $this->model->getPKField(), 'title_field' => $this->model->getTitleField(), 'table' => $this->model->getTable(), 'useAutoIncrement' => $this->model->useAutoIncrement(), 'class_path' => $this->getClassPaths(false) ]); } return $this->_form; } public function getHelper(): MylogHelper { if ($this->_helper === null) { $this->_helper = new MylogHelper(); $this->_helper->setAttributes([ 'pk_field' => $this->model->getPKField(), 'title_field' => $this->model->getTitleField(), 'table' => $this->model->getTable(), 'useAutoIncrement' => $this->model->useAutoIncrement(), 'class_path' => $this->getClassPaths(false) ]); } return $this->_helper; } /** * LogService는 START/SUCCESS/FAILURE 로그를 기록합니다. * LogService는 파이프라인의 시작과 끝에서만 Executor에 의해 직접 호출됩니다. */ public function log(OperationContext $context, string $status): void { if ($status === STATUS['FAILED'] && $context->error) { $message = "[{$context->action}_{$status}] Error: {$context->error->getMessage()}"; } else { $message = "[{$context->action}_{$status}] Steps Executed: " . count($context->pipelineDatas); } log_message('debug', $message); $formDatas = []; $formDatas['user'] = $context->auth->getUID(); $this->create(new MylogDTO()); } // PipelineStep 구현은 이 예시에서는 사용하지 않습니다. (로그는 Executor가 감쌈) public function handle(OperationContext $context): OperationContext { return $context; } //기본 기능부분 protected function getEntity_process(mixed $entity): MylogEntity { return $entity; } protected function create_process(array $formDatas): MylogEntity { return new MylogEntity($formDatas); } public function create(object $dto): MylogEntity { if (!$dto instanceof MylogDTO) { throw new RuntimeException(__METHOD__ . "에서 오류발생:" . get_class($dto) . "는 사용할수 없습니다."); } return parent::create($dto); } protected function modify_process($uid, array $formDatas): MyLogEntity { return parent::modify_process($uid, $formDatas); } public function modify($uid, object $dto): MyLogEntity { if (!$dto instanceof MylogDTO) { throw new RuntimeException(__METHOD__ . "에서 오류발생:" . get_class($dto) . "는 사용할수 없습니다."); } return parent::modify($uid, $dto); } }