where('status', DEFAULTS['STATUS']); $this->orderBy(self::TITLE, 'asc'); $options = parent::getFormFieldOption($field, $options); break; } return $options; } public function getEntityByPK(int $uid): null | ZoneEntity { $this->where(self::PK, $uid); return $this->getEntity(); } public function getEntityByID(string $id): null | ZoneEntity { $this->where(self::TITLE, $id); return $this->getEntity(); } public function getEntitysByParent(AccountEntity $account_entity) { $this->where(self::PARENT, $account_entity->getPK()); return $this->getEntitys(); } //create용 public function create(array $formDatas = []): ZoneEntity { return $this->create_process(new ZoneEntity(), $formDatas); } //modify용 public function modify(ZoneEntity $entity, array $formDatas): ZoneEntity { return $this->modify_process($entity, $formDatas); } //도메인이 이미 존재하는지 체크 public function isUniqueDomain(string $account_uid, string $domain): bool { $this->where(self::PARENT, $account_uid); $this->where(self::TITLE, $domain); return is_null($this->first()) ? true : false; } //Index 검색용 public function setIndexWordFilter(string $word): void { $subquery = $this->db->table(RecordModel::TABLE)->select(RecordModel::PARENT)->like('content', $word, 'both'); $this->like(self::TITLE, $word, 'both'); //befor , after , both $this->orWhereIn(self::PK, $subquery); } public function setIndexDateFilter($start, $end): void { $this->where('created_at >=', $start); $this->where('created_at <=', $end); } public function setIndexOrderBy($field, $order = 'ASC') { $this->orderBy(self::TITLE . " ASC, {$field} {$order}"); } }