_className .= '/HPILO'; $this->_model = new HPILOModel(); helper($this->_className); $this->_viewPath = strtolower($this->_className); $this->_viewDatas['title'] = lang($this->_className . '.title'); $this->_viewDatas['className'] = $this->_className; } private function getAdapter(HPILOEntity $entity) { if (is_null($this->_adapter)) { $adapterClass = getenv('hpilo.api.adapter') ?: "\App\Libraries\Adapter\API\GuzzleAdapter"; $this->_adapter = new $adapterClass(getenv('hpilo.api.debug') ?: false); $this->_adapter->setServerInfo($entity->getIP(), $entity->getPort()); $this->_adapter->setAccountInfo($entity->getID(), $entity->getPassword()); } return $this->_adapter; } //Insert관련 protected function insert_validate() { parent::insert_validate(); //IP형식 검사 모든 ip형식 사용가능 if (!isIPAddress_CommonHelper($this->_viewDatas['fieldDatas']['ip'], 'all')) { throw new \Exception("{$this->_viewDatas['title']}의 all, {$this->_viewDatas['fieldDatas']['ip']} 형식 오류"); } } ////추가 Action final public function console(int $uid) { $entity = $this->_model->getEntity($uid); $ilo = new HPILO4($this->getAdapter($entity)); $this->_viewDatas['SessionKey'] = $ilo->console(); $this->_viewDatas['entity'] = $entity; return view($this->_viewPath . '/console_iframe', $this->_viewDatas); } final public function reset(int $uid, string $type) { try { $entity = $this->_model->getEntity($uid); if (!in_array($type, ["On", "Off", "Restart"])) { throw new \Exception(__FUNCTION__ . "에서 {$type}은 기능은 없습니다."); } $ilo = new HPILO4($this->getAdapter($entity)); $results = $ilo->reset($type); log_message("warning", var_export($results, true)); $message = "{$entity->getTitle()} " . __FUNCTION__ . " 완료하였습니다."; log_message("info", "{$this->_viewDatas['title']} {$message}"); return alert_CommonHelper($message, $this->_session->get(SESSION_NAMES['RETURN_URL'])); } catch (\Exception $e) { $message = "{$entity->getTitle()} " . __FUNCTION__ . " 실패하였습니다."; log_message("warning", $message . "
\n{$e->getMessage()}"); log_message("info", "{$this->_viewDatas['title']} {$message}"); return alert_CommonHelper($message, 'back'); } } private function refresh(HPILO4 $ilo, HPILOEntity $entity) { $entity = $ilo->refresh($entity); if ($entity->hasChanged()) { if (!$this->_model->save($entity)) { log_message("error", __FUNCTION__ . "에서 호출:" . $this->_model->getLastQuery()); log_message("error", implode("\n", $this->_model->errors())); throw new \Exception(__FUNCTION__ . " 오류 발생.\n" . var_export($this->_model->errors())); } } return $entity; } final public function reload(int $uid) { try { $entity = $this->_model->getEntity($uid); $ilo = new HPILO4($this->getAdapter($entity)); // throw new \Exception(var_export($ilo, true)); $entity = $this->refresh($ilo, $entity); $message = "{$entity->getTitle()} " . __FUNCTION__ . " 완료하였습니다."; log_message("info", "{$this->_viewDatas['title']} {$message}"); return alert_CommonHelper($message, $this->_session->get(SESSION_NAMES['RETURN_URL'])); } catch (\Exception $e) { $message = "{$entity->getTitle()} " . __FUNCTION__ . " 실패하였습니다."; log_message("warning", $message . "
\n{$e->getMessage()}"); log_message("info", "{$this->_viewDatas['title']} {$message}"); return alert_CommonHelper($message, 'back'); } } }