addClassPaths('Account'); } protected function getDTOClass(): string { return AccountDTO::class; } public function createDTO(array $formDatas): AccountDTO { return new AccountDTO($formDatas); } public function getEntityClass(): string { return AccountEntity::class; } public function getFormService(): AccountForm { if ($this->_form === null) { $this->_form = new AccountForm(); $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(): AccountHelper { if ($this->_helper === null) { $this->_helper = new AccountHelper(); $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; } public function action_init_process(string $action, array $formDatas = []): void { $fields = [ "clientinfo_uid", "bank", "title", "alias", "issue_at", "amount", "status", "content" ]; $filters = [ "clientinfo_uid", "bank", "status", ]; $indexFilter = $filters; $batchjobFilters = ['bank', 'status']; switch ($action) { case 'create': case 'create_form': break; case 'modify': case 'modify_form': $fields = [...$fields, 'status']; break; case 'view': $fields = [...$fields, 'created_at']; break; case 'index': case 'download': $fields = [ "clientinfo_uid", "bank", "title", "alias", "issue_at", "amount", "status", 'created_at', ]; break; } $this->getFormService()->setFormFields($fields); $this->getFormService()->setFormRules($action, $fields); $this->getFormService()->setFormFilters($filters); $this->getFormService()->setFormOptions($action, $filters, $formDatas); $this->getFormService()->setIndexFilters($indexFilter); $this->getFormService()->setBatchjobFilters($batchjobFilters); } //기본 기능부분 protected function getEntity_process(mixed $entity): AccountEntity { return $entity; } protected function create_process(array $formDatas): AccountEntity { $entity = parent::create_process($formDatas); return $entity; } protected function modify_process($entity, array $formDatas): AccountEntity { throw new RuntimeException("예치금정보는 수정이 불가합니다."); } //List 검색용 //FormFilter 조건절 처리 //검색어조건절처리 public function setSearchWord(string $word): void { $this->model->orLike($this->model->getTable() . '.alias', $word, 'both'); parent::setSearchWord($word); } //결제처리 관련 protected function createByPayment_process(PaymentEntity $paymentEntity, array $formDatas = []): array { $formDatas['bank'] = $formDatas['alias'] = '결제차감'; $formDatas['amount'] = $paymentEntity->getAmount(); return parent::createByPayment_process($paymentEntity, $formDatas); } //입금처리 protected function setDeposit_process(ClientEntity $clientEntity, int $amount): int { $calculatedBalance = $balance = $clientEntity->getAccountBalance(); $field = "account_balance"; if ($balance < $amount) { throw new RuntimeException(sprintf( "%s 에서 오류발생: %s 고객의 예치금액(%s원)이 출금액(%s원) 보다 부족합니다.", static::class . '->' . __FUNCTION__, $clientEntity->getTitle(), number_format($balance), number_format($amount) )); } //최종처리 $calculatedBalance = $balance - $amount; service('customer_clientservice')->modify_process($clientEntity, ['account_balance' => $calculatedBalance]); return $calculatedBalance; } //출금처리 protected function setWithdrawal_process(ClientEntity $clientEntity, int $amount): int { $calculatedBalance = $balance = $clientEntity->getAccountBalance(); if ($balance < $amount) { throw new RuntimeException(sprintf( "%s 에서 오류발생: %s 고객의 예치금액(%s원)이 출금액(%s원) 보다 부족합니다.", static::class . '->' . __FUNCTION__, $clientEntity->getTitle(), number_format($balance), number_format($amount) )); } //최종처리 $calculatedBalance = $balance - $amount; service('customer_clientservice')->modify_process($clientEntity, ['account_balance' => $calculatedBalance]); return $calculatedBalance; } }