addClassPaths('User'); } public function getEntityClass(): string { return UserEntity::class; } //기본 기능부분 protected function getEntity_process(mixed $entity): UserEntity { return $entity; } protected function fieldhook_process(string $field, $value, array $formDatas): array { switch ($field) { case 'role': $arr = is_array($value) ? $value : explode(',', (string) $value); $arr = array_values(array_filter(array_map('trim', $arr))); sort($arr); $formDatas[$field] = implode(',', $arr); break; case 'passwd': if ($formDatas[$field] !== '') { $formDatas[$field] = password_hash($value, PASSWORD_BCRYPT); } else { unset($formDatas[$field]); } break; case 'confirmpassword': unset($formDatas['confirmpassword']); break; default: $formDatas = parent::fieldhook_process($field, $value, $formDatas); break; } return $formDatas; } //List 검색용 //FormFilter 조건절 처리 public function setFilter(string $field, mixed $filter_value): void { switch ($field) { case 'role': //FIND_IN_SET()은 MySQL 함수이므로 CodeIgniter가 이를 일반 컬럼명으로 착각하고 escape하게 되면 오류가 발생 // 따라서 ->where($sql, null, false)로 명시하여 escape를 꺼줘야 정상 작동 $where = "FIND_IN_SET(" . $this->model->escape($filter_value) . ", {$this->model->getTable()}.{$field}) > 0"; $this->model->where($where, null, false); break; default: parent::setFilter($field, $filter_value); break; } } //검색어조건절처리 public function setSearchWord(string $word): void { $this->model->orLike($this->model->getTable() . '.id', $word, 'both'); $this->model->orLike($this->model->getTable() . '.email', $word, 'both'); parent::setSearchWord($word); } }