126 lines
4.2 KiB
PHP
126 lines
4.2 KiB
PHP
<?php
|
|
|
|
namespace App\Models\Cloudflare;
|
|
|
|
use App\Models\CommonModel;
|
|
use App\Entities\Cloudflare\ZoneEntity;
|
|
use App\Entities\Cloudflare\AccountEntity;
|
|
|
|
class ZoneModel extends CommonModel
|
|
{
|
|
const TABLE = "cloudflarezone";
|
|
const PK = "uid";
|
|
const TITLE = "domain";
|
|
const PARENT = "account_uid";
|
|
protected $table = self::TABLE;
|
|
protected $primaryKey = self::PK;
|
|
protected $useAutoIncrement = false;
|
|
protected $returnType = ZoneEntity::class; //object,array,entity명::class
|
|
protected $allowedFields = [self::PK, self::PARENT, self::TITLE, 'name_servers', 'original_name_servers', 'plan', 'development_mode', 'ipv6', 'security_level', 'status', 'updated_at', 'crated_at '];
|
|
protected $useTimestamps = true;
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
public function getTitleField(): string
|
|
{
|
|
return self::TITLE;
|
|
}
|
|
public function getFieldRule(string $action, string $field): string
|
|
{
|
|
switch ($field) {
|
|
case self::PARENT:
|
|
$rule = "required|regex_match[/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/]";
|
|
break;
|
|
case self::TITLE:
|
|
case "plan":
|
|
$rule = "required|trim|string";
|
|
break;
|
|
case "name_servers":
|
|
case "security_level":
|
|
$rule = "if_exist|trim|string";
|
|
break;
|
|
case "development_mode":
|
|
case "ipv6":
|
|
$rule = "if_exist|in_list[on,off]";
|
|
break;
|
|
default:
|
|
$rule = parent::getFieldRule($action, $field);
|
|
break;
|
|
}
|
|
return $rule;
|
|
}
|
|
public function getFormFieldOption(string $field, array $options = []): array
|
|
{
|
|
switch ($field) {
|
|
default:
|
|
$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(AccountEntity $account_entity, string $domain): bool
|
|
{
|
|
$this->where(self::PARENT, $account_entity->getPK());
|
|
$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검색)을 하기위함
|
|
$this->join(RecordModel::TABLE, sprintf(
|
|
"%s.%s=%s.%s",
|
|
self::TABLE,
|
|
self::PK,
|
|
RecordModel::TABLE,
|
|
RecordModel::PARENT
|
|
));
|
|
parent::setList_WordFilter($word, $field);
|
|
$this->orLike(RecordModel::TABLE . '.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
|
|
{
|
|
//Join을 해서 도메인부터 Sorting하기위함
|
|
$this->join(AccountModel::TABLE, sprintf(
|
|
"%s.%s=%s.%s",
|
|
self::TABLE,
|
|
self::PARENT,
|
|
AccountModel::TABLE,
|
|
AccountModel::PK
|
|
));
|
|
$this->orderBy(AccountModel::TABLE . ".title ASC");
|
|
parent::setList_OrderBy($order);
|
|
}
|
|
}
|