'off', 'ipv6' => 'off', 'security_level' => 'medium']; public function __construct(AccountEntity $account_entity) { $this->_account_entity = $account_entity; $auth_entity = $this->getAuthModel()->getEntityByPK($this->_account_entity->getParent()); if ($auth_entity === null) { throw new \Exception("해당 계정정보를 찾을수 없습니다."); } parent::__construct($auth_entity); } protected function getModel(): ZoneModel { if ($this->_model === null) { $this->_model = new ZoneModel(); } return $this->_model; } protected function getArrayByResult($result, array $formDatas = []): array { $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($result, true)); return $formDatas; } //Cfzone에서 가져온 값을 zone에 setting private function getCFSetting(string $uid, array $formDatas = []): array { $cf = $this->getMySocket()->get('zones/' . $uid . '/settings'); $cf = json_decode($cf->getBody()); if (!$cf->success) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } foreach ($cf->result as $result) { if (in_array(needle: $result->id, haystack: array_keys($this->_setting_fields))) { $formDatas[$result->id] = $result->value; } } // log_message("debug", var_export($cf, return: true)); return $formDatas; } private function getCFSettingSSL(string $uid, array $formDatas = []): array { $cf = $this->getMySocket()->get('zones/' . $uid . '/settings/ssl'); $cf = json_decode($cf->getBody()); if (!$cf->success) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } log_message("debug", var_export($cf->result, true)); $formDatas['ssl_mode'] = $cf->result->value; // log_message("debug", var_export($cf, return: true)); // exit; return $formDatas; } private function setCFSetting(string $uid, string $field, string $value): string { $datas = ['value' => $value]; $cf = $this->getMySocket()->patch('zones/' . $uid . '/settings/' . $field, $datas); $cf = json_decode($cf->getBody()); if (!$cf->success || $cf->result->id !== $field) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nrequest:" . var_export($datas, true) . "\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } //최종 결과값은 body->result->id='필드명',body->result->value='on/off'이런식으로 받음 return $cf->result->value; } private function setCFSettingSSL(string $uid, string $field, string $value): string { $datas = ['value' => $value]; $cf = $this->getMySocket()->patch('zones/' . $uid . '/settings/ssl', $datas); $cf = json_decode($cf->getBody()); if (!$cf->success || $cf->result->id !== $field) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nrequest:" . var_export($datas, true) . "\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } //최종 결과값은 body->result->id='필드명',body->result->value='on/off'이런식으로 받음 return $cf->result->value; } public function create(string $domain, bool $jump_start = false): ZoneEntity { //Socket용 //도메인생성을 위해 Cloudflare에 전송 $datas = [ 'accountId' => $this->_account_entity->getPK(), 'name' => $domain, 'jump_start' => $jump_start, ]; $cf = $this->getMySocket()->post('zones/', $datas); $cf = json_decode($cf->getBody()); if (!$cf->success) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nrequest:" . var_export($datas, true) . "\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } //DB생성 $formDatas = $this->getArrayByResult($cf->result); foreach ($this->_setting_fields as $field => $default) { //초기화값 추가셋팅 ipv6 , development_mode , security_level $formDatas[$field] = $this->setCFSetting($formDatas[ZoneModel::PK], $field, $default); } return $this->getModel()->create($formDatas); } public function modify(ZoneEntity $entity, array $formDatas): ZoneEntity { // throw new \Exception("zone:modify" . var_export($formDatas, true)); foreach ($formDatas as $field => $value) { if ($field === 'ssl_mode') { $formDatas[$field] = $this->setCFSettingSSL($entity->getPK(), $field, $value); } else { //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(ZoneEntity $entity): ZoneEntity { $cf = $this->getMySocket()->delete("zones/{$entity->getPK()}"); $cf = json_decode($cf->getBody()); if (!$cf->success) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } //DB삭제 $this->getModel()->where(ZoneModel::PK, $entity->getPK()); $this->getModel()->delete(); log_message("debug", $this->getModel()->getLastQuery()); return $entity; } public function sync(ZoneEntity $entity): ZoneEntity { $cf = $this->getMySocket()->get("zones/{$entity->getPK()}"); $cf = json_decode($cf->getBody()); if (!$cf->success) { $message = "Zone:" . __FUNCTION__ . "에서 실패:\nresponse:" . var_export($cf, true); log_message("error", $message); throw new \Exception($message); } $formDatas = $this->getArrayByResult($cf->result); // log_message("debug", var_export($formDatas, true)); $formDatas = $this->getCFSetting($formDatas[ZoneModel::PK], $formDatas); // log_message("debug", var_export($formDatas, true)); $formDatas = $this->getCFSettingSSL($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; } //Reload public function reload(): array { log_message("notice", "\n-----------Account {$this->_account_entity->getTitle()}의 Zone처리 시작-----------"); $entitys = []; try { $zone_results = $this->reload_procedure("zones"); if (count($zone_results) > 0) { foreach ($zone_results as $result) { $formDatas = $this->getArrayByResult($result); $formDatas = $this->getCFSetting($formDatas[ZoneModel::PK], $formDatas); $formDatas = $this->getCFSettingSSL($formDatas[ZoneModel::PK], $formDatas); $entitys[$formDatas[ZoneModel::PK]] = $this->getModel()->modify(new ZoneEntity(), $formDatas); } //부모키를 기준으로 CF에 존재하지 않는 데이터 삭제용 $this->getModel()->where(ZoneModel::PARENT, $this->_account_entity->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->_account_entity->getTitle()}의 Zone 처리[" . count($entitys) . "개] 완료-----------"); return $entitys; } }