'off', 'ipv6' => 'off', 'security_level' => 'medium', 'ssl' => 'flexible', 'always_use_https' => 'off' ]; public function __construct() { $this->class_name = "Zone"; parent::__construct(); $this->class_path .= $this->class_name; } private function getParentEntity(): AccountEntity { if ($this->_parent_entity === null) { throw new \Exception(__FUNCTION__ . "에서 부모정보가 없습니다."); } return $this->_parent_entity; } private function setParentEntity(mixed $parent_entity): void { $this->_parent_entity = $parent_entity; $auth_entity = $this->getAuthModel()->getEntityByPK(uid: $this->getParentEntity()->getParent()); if ($auth_entity === null) { throw new \Exception("해당 계정정보를 찾을수 없습니다."); } $this->setAuthEntity($auth_entity); } protected function getModel(): ZoneModel { if ($this->_model === null) { $this->_model = new ZoneModel(); } return $this->_model; } protected function getArrayByResult(\stdClass $result, array $formDatas = []): array { // log_message("debug", var_export($result, true)); $formDatas[ZoneModel::PK] = $result->id; $formDatas[ZoneModel::PARENT] = $result->account->id; $formDatas[ZoneModel::TITLE] = $result->name; $formDatas['status'] = $result->status; //$formDatas['type'] = $result->type; // full 이게있는데 뭔지 잘모름 $formDatas['name_servers'] = 'none'; if (isset($result->name_servers)) { $formDatas['name_servers'] = is_array($result->name_servers) ? implode( ',', $result->name_servers ) : $result->name_servers; } $formDatas['original_name_servers'] = 'none'; if (isset($result->original_name_servers)) { $formDatas['original_name_servers'] = is_array($result->original_name_servers) ? implode( ',', $result->original_name_servers ) : $result->original_name_servers; } // $formDatas['updated_at'] = $result->modified_on; $formDatas['updated_at'] = date("Y-m-d H:i:s"); $formDatas['created_at'] = $result->created_on; $formDatas['plan'] = $result->plan->name; // log_message("debug", var_export($formDatas, true)); return $formDatas; } //Cfzone에서 가져온 값을 zone에 setting private function getCFSetting(string $uid, array $formDatas = []): array { $response = $this->getMySocket()->get('zones/' . $uid . '/settings'); $body = json_decode($response->getBody()); // log_message("debug", var_export($body, true)); foreach ($body->result as $result) { if (in_array(needle: $result->id, haystack: array_keys($this->_setting_fields))) { $formDatas[($result->id === 'ssl') ? 'ssl_mode' : $result->id] = $result->value; } } // log_message("debug", var_export($cf, return: true)); return $formDatas; } private function setCFSetting(string $uid, string $field, string $value): string { $field = ($field === 'ssl_mode') ? 'ssl' : $field; $datas = ['value' => $value]; $response = $this->getMySocket()->patch('zones/' . $uid . '/settings/' . $field, $datas); $body = json_decode($response->getBody()); //최종 결과값은 body->result->id='필드명',body->result->value='on/off'이런식으로 받음 return $body->result->value; } public function create(AccountEntity $parent_entity, string $domain, bool $jump_start = false): ZoneEntity { //부모데이터정의 $this->setParentEntity($parent_entity); //Socket용 //도메인생성을 위해 Cloudflare에 전송 $datas = [ 'accountId' => $this->getParentEntity()->getPK(), 'name' => $domain, 'jump_start' => $jump_start, ]; $response = $this->getMySocket()->post('zones/', $datas); $body = json_decode($response->getBody()); //DB생성 $formDatas = $this->getArrayByResult($body->result); foreach ($this->_setting_fields as $field => $default) { //초기화값 추가셋팅 ipv6 , development_mode , security_level $formDatas[$field] = $this->setCFSetting($formDatas[ZoneModel::PK], $field, $default); } $entity = $this->getModel()->create($formDatas); log_message("debug", "Zone:{$entity->getTitle()} 작업을 완료하였습니다."); return $entity; } public function modify(AccountEntity $parent_entity, ZoneEntity $entity, array $formDatas): ZoneEntity { //부모데이터정의 $this->setParentEntity($parent_entity); // throw new \Exception("zone:modify" . var_export($formDatas, true)); foreach ($formDatas as $field => $value) { //modify,toggle,batchjob 사용 셋팅 ipv6 , //development_mode , //security_level $formDatas[$field] = $this->setCFSetting($entity->getPK(), $field, $value); } //DB수정 return $this->getModel()->modify($entity, $formDatas); } public function delete(AccountEntity $parent_entity, ZoneEntity $entity): ZoneEntity { //부모데이터정의 $this->setParentEntity($parent_entity); $this->getMySocket()->delete("zones/{$entity->getPK()}"); //DB삭제 $this->getModel()->delete($entity->getPK()); log_message("debug", $this->getModel()->getLastQuery()); return $entity; } public function sync(AccountEntity $parent_entity, ZoneEntity $entity): ZoneEntity { $this->setParentEntity($parent_entity); $response = $this->getMySocket()->get("zones/{$entity->getPK()}"); $body = json_decode($response->getBody()); $formDatas = $this->getArrayByResult($body->result); // log_message("debug", var_export($formDatas, true)); $formDatas = $this->getCFSetting($formDatas[ZoneModel::PK], $formDatas); // log_message("debug", var_export($formDatas, true)); $entity = $this->getModel()->modify($entity, $formDatas); // log_message("debug", $this->getModel()->getLastQuery()); return $entity; } public function expire(ZoneEntity $entity): void { $whois = Factory::get()->createWhois(); if ($whois->isDomainAvailable($entity->getTitle())) { $info = $whois->loadDomainInfo($entity->getTitle()); $expire_date = date("Y-m-d", $info->expirationDate); $this->getModel()->modify($entity, ['expire_date' => $expire_date]); log_message('debug', __FUNCTION__ . " : {$entity->getTitle()} => {$expire_date}"); } else { log_message('debug', "{$entity->getTitle()} 이 도메인은 등록되지 않았습니다."); } } //Reload public function reload(AccountEntity $parent_entity): array { //부모데이터정의 $this->setParentEntity($parent_entity); log_message("notice", "\n-----------Account {$this->getParentEntity()->getTitle()}의 Zone처리 시작-----------"); $entitys = []; try { $results = $this->reload_procedure("zones"); $cnt = 1; $total = count($results); if ($total > 0) { foreach ($results as $result) { if (!is_object($result) || get_class($result) !== 'stdClass') { log_message("error", "Zone: result is not a stdClass:\n" . var_export($result, true) . "\n"); continue; } if (isset($result->status) && $result->status === 'active') { $formDatas = $this->getArrayByResult($result); $formDatas = $this->getCFSetting($formDatas[ZoneModel::PK], $formDatas); $entity = $this->getModel()->modify(new ZoneEntity(), $formDatas); log_message("debug", "{$cnt}/{$total} => {$entity->getTitle()} Zone 처리,[{$this->getMySocket()::$_request}]"); $entitys[$entity->getPK()] = $entity; $cnt++; } else { log_message("error", "Zone is abnormal status:\n" . var_export($result, true) . "\n"); } } //부모키를 기준으로 CF에 존재하지 않는 데이터 삭제용 $this->getModel()->where(ZoneModel::PARENT, value: $this->getParentEntity()->getPK()); $this->getModel()->whereNotIn(ZoneModel::PK, array_keys($entitys)); $this->getModel()->delete(); // log_message("debug", $this->getModel()->getLastQuery()); } } catch (\Exception $e) { log_message("error", $e->getMessage()); throw new \Exception($e->getMessage()); } log_message("notice", "\n----------Account {$this->getParentEntity()->getTitle()}의 Zone 처리[" . count($entitys) . "개] 완료-----------"); return $entitys; } }