allowedFields = ["uid", ...$this->allowedFields, ...$fields]; $this->validationRules = [...$this->validationRules, ...$this->getFieldRules($this->allowedFields),]; } public function getTitleField(): string { return 'name'; } protected function getFieldRule(string $field, array $rules, string $action = ""): array { switch ($field) { case "id": $rules[$field] = "required|trim|min_length[4]|max_length[20]"; $rules[$field] .= $action == "insert" ? "|is_unique[{$this->table}.{$field}]" : ""; break; case "passwd": $rules[$field] = "required|trim|string"; if ($action != "") { $rules["confirmpassword"] = "required|trim|string|matches[passwd]"; } break; case $this->getTitleField(): $rules[$field] = "required|trim|string"; break; case "email": $rules[$field] = "required|trim|valid_email"; break; case "role": $rules[$field] = "required|string"; break; default: $rules = parent::getFieldRule($field, $rules, $action); break; } return $rules; } public function getEntity($conditions): UserEntity { return $this->where($conditions)->first() ?: throw new \Exception("해당 데이터가 없습니다.\n" . var_export($conditions, true)); } protected function changeFormData(string $action, string $field, array $formDatas, $entity) { switch ($field) { case "role": if (array_key_exists($field, $formDatas) && !is_null($formDatas[$field])) { $entity->$field = is_array($formDatas[$field]) ? implode("|", $formDatas[$field]) : $formDatas[$field]; } break; default: $entity = parent::changeFormData($action, $field, $formDatas, $entity); break; } return $entity; } public function create(array $formDatas): UserEntity { return $this->create_process(new UserEntity(), $formDatas); } public function modify(UserEntity $entity, array $formDatas): UserEntity { return $this->modify_process($entity, $formDatas); } //Index관련 public function setIndexWordFilter(string $word) { parent::setIndexWordFilter($word); $this->orLike("id", $word, "both"); $this->orLike($this->getTitleField(), $word, "both"); //befor , after , both } }