class_name . '.' . strtoupper($field)); break; default: $this->orderBy(self::TITLE, 'asc'); $options = parent::getFormFieldInputOption($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; } //List 검색용 public function setList_WordFilter(string $word, $field = null): void { //Join을 해서 Record의 content(IP검색)을 하기위함 parent::setList_WordFilter($word, $field); $this->join('cloudflarerecord', "cloudflarezone.uid=cloudflarerecord.zone_uid"); $this->orLike('cloudflarerecord.content', $word, 'both'); // $subquery = $this->db->table(RecordModel::TABLE)->select(RecordModel::PARENT)->like('content', $word, 'both'); // $this->orWhereIn(self::PK, $subquery); } public function setList_OrderBy(string $order): void { $this->orderBy(self::TITLE . " ASC"); parent::setList_OrderBy($order); } }