From 24e581d9572b94b8c49cdfc54f2b65850fbfc892 Mon Sep 17 00:00:00 2001 From: Pinga <121483313+getpinga@users.noreply.github.com> Date: Tue, 17 Sep 2024 11:33:45 +0300 Subject: [PATCH] Fixed #4 , fixed #5 --- README.md | 4 +- eppClient.php | 2619 ----------------------------------------- eppSync.php | 671 ++++++++++- install_epp_module.sh | 5 - 4 files changed, 633 insertions(+), 2666 deletions(-) delete mode 100644 eppClient.php diff --git a/README.md b/README.md index 0ef42cc..36ed326 100644 --- a/README.md +++ b/README.md @@ -48,9 +48,9 @@ Next, rename `epp.php` as `YourRegistryName.php`. Please ensure to replace "**Yo Proceed to open the newly renamed file and locate the phrase "**Registrar_Adapter_EPP**". Replace it with "**Registrar_Adapter_YourRegistryName**". -## 3. Addition of Synchronization Scripts: +## 3. Addition of Synchronization Script: -There are two additional scripts in the repository: **eppSync.php** and **eppClient.php**. These need to be placed in the main `[FOSSBilling]` directory. +There is one additional script in the repository: **eppSync.php**. It needs to be placed in the main `[FOSSBilling]` directory. Rename `eppSync.php` to `YourRegistryNameSync.php`. diff --git a/eppClient.php b/eppClient.php deleted file mode 100644 index 0de4ea9..0000000 --- a/eppClient.php +++ /dev/null @@ -1,2619 +0,0 @@ - array( - 'verify_peer' => (bool)$params['verify_peer'], - 'verify_peer_name' => (bool)$params['verify_peer_name'], - 'verify_host' => (bool)$params['verify_host'], - 'cafile' => (string)$params['cafile'], - 'local_cert' => (string)$params['local_cert'], - 'local_pk' => (string)$params['local_pk'], - 'passphrase' => (string)$params['passphrase'], - 'allow_self_signed' => (bool)$params['allow_self_signed'], - 'min_tls_version' => $tls - ) - ); - if ($bind) { - $opts['socket'] = array('bindto' => $bindip); - } - $context = stream_context_create($opts); - $this->resource = stream_socket_client("tls://{$host}:{$port}", $errno, $errmsg, $timeout, STREAM_CLIENT_CONNECT, $context); - if (!$this->resource) { - throw new \exception("Cannot connect to server '{$host}': {$errmsg}"); - } - - return $this->readResponse(); - } - - /** - * readResponse - */ - public function readResponse() - { - $hdr = stream_get_contents($this->resource, 4); - if ($hdr === false) { - throw new \exception('Connection appears to have closed.'); - } - if (strlen($hdr) < 4) { - throw new \exception('Failed to read header from the connection.'); - } - $unpacked = unpack('N', $hdr); - $xml = fread($this->resource, ($unpacked[1] - 4)); - $xml = preg_replace('/>\n<", $xml); - $this->_response_log($xml); - return $xml; - } - - /** - * writeRequest - */ - public function writeRequest($xml) - { - $this->_request_log($xml); - if (fwrite($this->resource, pack('N', (strlen($xml) + 4)) . $xml) === false) { - throw new exception('Error writing to the connection.'); - } - $xml_string = $this->readResponse(); - libxml_use_internal_errors(true); - - $r = simplexml_load_string($xml_string, 'SimpleXMLElement', LIBXML_DTDLOAD | LIBXML_NOENT); - if ($r instanceof SimpleXMLElement) { - $r->registerXPathNamespace('e', 'urn:ietf:params:xml:ns:epp-1.0'); - $r->registerXPathNamespace('xsi', 'http://www.w3.org/2001/XMLSchema-instance'); - $r->registerXPathNamespace('domain', 'urn:ietf:params:xml:ns:domain-1.0'); - $r->registerXPathNamespace('contact', 'urn:ietf:params:xml:ns:contact-1.0'); - $r->registerXPathNamespace('host', 'urn:ietf:params:xml:ns:host-1.0'); - $r->registerXPathNamespace('rgp', 'urn:ietf:params:xml:ns:rgp-1.0'); - } - if (isset($r->response) && $r->response->result->attributes()->code >= 2000) { - throw new \exception($r->response->result->msg); - } - return $r; - } - - /** - * disconnect - */ - public function disconnect() - { - if (!fclose($this->resource)) { - throw new \exception('Error closing the connection.'); - } - $this->resource = null; - } - - /** - * wrapper for functions - */ - public function __call($func, $args) - { - if (!function_exists($func)) { - throw new \Exception("Call to undefined method Epp::$func()."); - } - - if ($func === 'connect') { - try { - $result = call_user_func_array($func, $args); - } catch (\ErrorException $e) { - throw new \Exception($e->getMessage()); - } - - if (!is_resource($this->resource)) { - throw new \Exception('An error occured while trying to connect to EPP server.'); - } - - $result = null; - } elseif (!is_resource($this->resource)) { - throw new EppNotConnectedException(); - } else { - array_unshift($args, $this->resource); - try { - $result = call_user_func_array($func, $args); - } catch (\ErrorException $e) { - throw new \Exception($e->getMessage()); - } - } - - return $result; - } - - /** - * login - */ - public function login($params = array()) - { - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ clID }}/'; - $to[] = htmlspecialchars($params['clID']); - $from[] = '/{{ pwd }}/'; - $to[] = htmlspecialchars($params['pw']); - if (isset($params['newpw']) && !empty($params['newpw'])) { - $from[] = '/{{ newpw }}/'; - $to[] = PHP_EOL . ' ' . htmlspecialchars($params['newpw']) . ''; - } else { - $from[] = '/{{ newpw }}/'; - $to[] = ''; - } - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($params['prefix'] . '-login-' . $microtime); - $xml = preg_replace($from, $to, ' - - - - {{ clID }} - {{ pwd }}{{ newpw }} - - 1.0 - en - - - urn:ietf:params:xml:ns:domain-1.0 - urn:ietf:params:xml:ns:contact-1.0 - urn:ietf:params:xml:ns:host-1.0 - - urn:ietf:params:xml:ns:secDNS-1.1 - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - if ($code == 1000) { - $this->isLoggedIn = true; - $this->prefix = $params['prefix']; - } - - $return = array( - 'code' => $code, - 'msg' => $r->response->result->msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * logout - */ - public function logout($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-logout-' . $microtime); - $xml = preg_replace($from, $to, ' - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - if ($code == 1500) { - $this->isLoggedIn = false; - } - - $return = array( - 'code' => $code, - 'msg' => $r->response->result->msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * hello - */ - public function hello() - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-hello-' . $microtime); - $xml = preg_replace($from, $to, ' - - -'); - $r = $this->writeRequest($xml); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $r->asXML(); - } - - /** - * hostCheck - */ - public function hostCheck($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['hostname']); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-host-check-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:host-1.0')->chkData; - - $i = 0; - foreach ($r->cd as $cd) { - $i++; - $hosts[$i]['name'] = (string)$cd->name; - $hosts[$i]['reason'] = (string)$cd->reason; - $hosts[$i]['avail'] = (int)$cd->name->attributes()->avail; - } - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'hosts' => $hosts - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * hostInfo - */ - public function hostInfo($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['hostname']); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-host-info-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:host-1.0')->infData[0]; - $name = (string)$r->name; - $addr = array(); - foreach ($r->addr as $ns) { - $addr[] = (string)$ns; - } - $status = array(); - $i = 0; - foreach ($r->status as $e) { - $i++; - $status[$i] = (string)$e->attributes()->s; - } - $clID = (string)$r->clID; - $crID = (string)$r->crID; - $crDate = (string)$r->crDate; - $upID = (string)$r->upID; - $upDate = (string)$r->upDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'status' => $status, - 'addr' => $addr, - 'clID' => $clID, - 'crID' => $crID, - 'crDate' => $crDate, - 'upID' => $upID, - 'upDate' => $upDate - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * hostCreate - */ - public function hostCreate($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['hostname']); - $from[] = '/{{ ip }}/'; - $to[] = htmlspecialchars($params['ipaddress']); - $from[] = '/{{ v }}/'; - $to[] = (preg_match('/:/', $params['ipaddress']) ? 'v6' : 'v4'); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-host-create-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ ip }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:host-1.0')->creData; - $name = (string)$r->name; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * hostUpdate - */ - public function hostUpdate($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['hostname']); - $from[] = '/{{ ip1 }}/'; - $to[] = htmlspecialchars($params['currentipaddress']); - $from[] = '/{{ v1 }}/'; - $to[] = (preg_match('/:/', $params['currentipaddress']) ? 'v6' : 'v4'); - $from[] = '/{{ ip2 }}/'; - $to[] = htmlspecialchars($params['newipaddress']); - $from[] = '/{{ v2 }}/'; - $to[] = (preg_match('/:/', $params['newipaddress']) ? 'v6' : 'v4'); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-host-update-' . $clTRID); - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - {{ ip2 }} - - - {{ ip1 }} - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * hostDelete - */ - public function hostDelete($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['hostname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-host-delete-' . $clTRID); - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - - '); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * contactCheck - */ - public function contactCheck($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ id }}/'; - $id = $params['contact']; - $to[] = htmlspecialchars($id); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-contact-check-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ id }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:contact-1.0')->chkData; - - $i = 0; - foreach ($r->cd as $cd) { - $i++; - $contacts[$i]['id'] = (string)$cd->id; - $contacts[$i]['avail'] = (int)$cd->id->attributes()->avail; - $contacts[$i]['reason'] = (string)$cd->reason; - } - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'contacts' => $contacts - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * contactInfo - */ - public function contactInfo($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ id }}/'; - $to[] = htmlspecialchars($params['contact']); - $from[] = '/{{ authInfo }}/'; - $authInfo = (isset($params['authInfoPw']) ? "\n\n" : ''); - $to[] = $authInfo; - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-contact-info-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ id }} - {{ authInfo }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:contact-1.0')->infData[0]; - - foreach ($r->postalInfo as $e) { - $name = (string)$e->name; - $org = (string)$e->org; - $street1 = $street2 = $street3 = ''; - for ($i = 0; $i <= 2; $i++) { - ${'street' . ($i + 1)} = (string)$e->addr->street[$i]; - } - $city = (string)$e->addr->city; - $state = (string)$e->addr->sp; - $postal = (string)$e->addr->pc; - $country = (string)$e->addr->cc; - } - $id = (string)$r->id; - $status = array(); - $i = 0; - foreach ($r->status as $e) { - $i++; - $status[$i] = (string)$e->attributes()->s; - } - $roid = (string)$r->roid; - $voice = (string)$r->voice; - $fax = (string)$r->fax; - $email = (string)$r->email; - $clID = (string)$r->clID; - $crID = (string)$r->crID; - $crDate = (string)$r->crDate; - $upID = (string)$r->upID; - $upDate = (string)$r->upDate; - $authInfo = (string)$r->authInfo->pw; - - $return = array( - 'id' => $id, - 'roid' => $roid, - 'code' => $code, - 'status' => $status, - 'msg' => $msg, - 'name' => $name, - 'org' => $org, - 'street1' => $street1, - 'street2' => $street2, - 'street3' => $street3, - 'city' => $city, - 'state' => $state, - 'postal' => $postal, - 'country' => $country, - 'voice' => $voice, - 'fax' => $fax, - 'email' => $email, - 'clID' => $clID, - 'crID' => $crID, - 'crDate' => $crDate, - 'upID' => $upID, - 'upDate' => $upDate, - 'authInfo' => $authInfo - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * contactCreate - */ - public function contactCreate($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ type }}/'; - $to[] = htmlspecialchars($params['type']); - $from[] = '/{{ id }}/'; - $to[] = htmlspecialchars($params['id']); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['firstname'] . ' ' . $params['lastname']); - $from[] = '/{{ org }}/'; - $to[] = htmlspecialchars($params['companyname']); - $from[] = '/{{ street1 }}/'; - $to[] = htmlspecialchars($params['address1']); - $from[] = '/{{ street2 }}/'; - $to[] = htmlspecialchars($params['address2']); - $from[] = '/{{ street3 }}/'; - $street3 = (isset($params['address3']) ? $params['address3'] : ''); - $to[] = htmlspecialchars($street3); - $from[] = '/{{ city }}/'; - $to[] = htmlspecialchars($params['city']); - $from[] = '/{{ state }}/'; - $to[] = htmlspecialchars($params['state']); - $from[] = '/{{ postcode }}/'; - $to[] = htmlspecialchars($params['postcode']); - $from[] = '/{{ country }}/'; - $to[] = htmlspecialchars($params['country']); - $from[] = '/{{ phonenumber }}/'; - $to[] = htmlspecialchars($params['fullphonenumber']); - $from[] = '/{{ email }}/'; - $to[] = htmlspecialchars($params['email']); - $from[] = '/{{ authInfo }}/'; - $to[] = htmlspecialchars($params['authInfoPw']); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-contact-create-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ id }} - - {{ name }} - {{ org }} - - {{ street1 }} - {{ street2 }} - {{ street3 }} - {{ city }} - {{ state }} - {{ postcode }} - {{ country }} - - - {{ phonenumber }} - - {{ email }} - - {{ authInfo }} - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:contact-1.0')->creData; - $id = (string)$r->id; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'id' => $id - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * contactUpdate - */ - public function contactUpdate($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ type }}/'; - $to[] = htmlspecialchars($params['type']); - $from[] = '/{{ id }}/'; - $to[] = htmlspecialchars($params['id']); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['firstname'] . ' ' . $params['lastname']); - $from[] = '/{{ org }}/'; - $to[] = htmlspecialchars($params['companyname']); - $from[] = '/{{ street1 }}/'; - $to[] = htmlspecialchars($params['address1']); - $from[] = '/{{ street2 }}/'; - $to[] = htmlspecialchars($params['address2']); - $from[] = '/{{ street3 }}/'; - $street3 = (isset($params['address3']) ? $params['address3'] : ''); - $to[] = htmlspecialchars($street3); - $from[] = '/{{ city }}/'; - $to[] = htmlspecialchars($params['city']); - $from[] = '/{{ state }}/'; - $to[] = htmlspecialchars($params['state']); - $from[] = '/{{ postcode }}/'; - $to[] = htmlspecialchars($params['postcode']); - $from[] = '/{{ country }}/'; - $to[] = htmlspecialchars($params['country']); - $from[] = '/{{ voice }}/'; - $to[] = htmlspecialchars($params['fullphonenumber']); - $from[] = '/{{ email }}/'; - $to[] = htmlspecialchars($params['email']); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-contact-update-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ id }} - - - {{ name }} - {{ org }} - - {{ street1 }} - {{ street2 }} - {{ street3 }} - {{ city }} - {{ state }} - {{ postcode }} - {{ country }} - - - {{ voice }} - - {{ email }} - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * contactDelete - */ - public function contactDelete($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ id }}/'; - $to[] = htmlspecialchars($params['contact']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-contact-delete-' . $clTRID); - $xml = preg_replace($from, $to, ' - - - - - {{ id }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainCheck - */ - public function domainCheck($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $text = ''; - foreach ($params['domains'] as $name) { - $text .= '' . $name . '' . "\n"; - } - $from[] = '/{{ names }}/'; - $to[] = $text; - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-check-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ names }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->chkData; - - $i = 0; - foreach ($r->cd as $cd) { - $i++; - $domains[$i]['name'] = (string)$cd->name; - $domains[$i]['avail'] = (int)$cd->name->attributes()->avail; - $domains[$i]['reason'] = (string)$cd->reason; - } - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'domains' => $domains - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainCheckClaims - */ - public function domainCheckClaims($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-checkClaims-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - - - claims - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $phase = $r->response->extension->children('urn:ietf:params:xml:ns:launch-1.0')->chkData->phase; - $status = $r->response->extension->children('urn:ietf:params:xml:ns:launch-1.0')->chkData->cd->name->attributes()->exists; - $name = $r->response->extension->children('urn:ietf:params:xml:ns:launch-1.0')->chkData->cd->name; - $claimKey = $r->response->extension->children('urn:ietf:params:xml:ns:launch-1.0')->chkData->cd->claimKey; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'domain' => $name, - 'status' => $status, - 'phase' => $phase, - 'claimKey' => $claimKey - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainInfo - */ - public function domainInfo($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ domainname }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ authInfo }}/'; - $authInfo = (isset($params['authInfoPw']) ? "\n\n" : ''); - $to[] = $authInfo; - $from[] = '/{{ clTRID }}/'; - $microtime = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-info-' . $microtime); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ domainname }} - {{ authInfo }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->infData; - $name = (string)$r->name; - $roid = (string)$r->roid; - $status = array(); - $i = 0; - foreach ($r->status as $e) { - $i++; - $status[$i] = (string)$e->attributes()->s; - } - $registrant = (string)$r->registrant; - $contact = array(); - $i = 0; - foreach ($r->contact as $e) { - $i++; - $contact[$i]['type'] = (string)$e->attributes()->type; - $contact[$i]['id'] = (string)$e; - } - $ns = array(); - $i = 0; - foreach ($r->ns->hostObj as $hostObj) { - $i++; - $ns[$i] = (string)$hostObj; - } - $host = array(); - $i = 0; - foreach ($r->host as $hostname) { - $i++; - $host[$i] = (string)$hostname; - } - $clID = (string)$r->clID; - $crID = (string)$r->crID; - $crDate = (string)$r->crDate; - $upID = (string)$r->upID; - $upDate = (string)$r->upDate; - $exDate = (string)$r->exDate; - $trDate = (string)$r->trDate; - $authInfo = (string)$r->authInfo->pw; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'roid' => $roid, - 'status' => $status, - 'registrant' => $registrant, - 'contact' => $contact, - 'ns' => $ns, - 'host' => $host, - 'clID' => $clID, - 'crID' => $crID, - 'crDate' => $crDate, - 'upID' => $upID, - 'upDate' => $upDate, - 'exDate' => $exDate, - 'trDate' => $trDate, - 'authInfo' => $authInfo - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainUpdateNS - */ - public function domainUpdateNS($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-info-' . $clTRID); - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - - '); - $r = $this->writeRequest($xml); - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->infData; - - $add = $rem = array(); - $i = 0; - foreach ($r->ns->hostObj as $ns) { - $i++; - $ns = (string)$ns; - if (!$ns) { - continue; - } - - $rem["ns{$i}"] = $ns; - } - - foreach ($params as $k => $v) { - if (!$v) { - continue; - } - - if (!preg_match("/^ns\d$/i", $k)) { - continue; - } - - if ($k0 = array_search($v, $rem)) { - unset($rem[$k0]); - } else { - $add[$k] = $v; - } - } - - if (!empty($add) || !empty($rem)) { - $from = $to = array(); - $text = ''; - foreach ($add as $k => $v) { - $text.= '' . $v . '' . "\n"; - } - - $from[] = '/{{ add }}/'; - $to[] = (empty($text) ? '' : "\n{$text}\n"); - $text = ''; - foreach ($rem as $k => $v) { - $text.= '' . $v . '' . "\n"; - } - - $from[] = '/{{ rem }}/'; - $to[] = (empty($text) ? '' : "\n{$text}\n"); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-updateNS-' . $clTRID); - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ add }} - {{ rem }} - - - {{ clTRID }} - - '); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainUpdateContact - */ - public function domainUpdateContact($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - if ($params['contacttype'] === 'registrant') { - $from[] = '/{{ add }}/'; - $to[] = ""; - $from[] = '/{{ rem }}/'; - $to[] = ""; - $from[] = '/{{ chg }}/'; - $to[] = "".htmlspecialchars($params['new_contactid'])."\n"; - } else { - $from[] = '/{{ add }}/'; - $to[] = "".htmlspecialchars($params['new_contactid'])."\n"; - $from[] = '/{{ rem }}/'; - $to[] = "".htmlspecialchars($params['old_contactid'])."\n"; - $from[] = '/{{ chg }}/'; - $to[] = ""; - } - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-updateContact-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ add }} - {{ rem }} - {{ chg }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainUpdateStatus - */ - public function domainUpdateStatus($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - if ($params['command'] === 'add') { - $from[] = '/{{ add }}/'; - $to[] = "\n"; - $from[] = '/{{ rem }}/'; - $to[] = ""; - } else if ($params['command'] === 'rem') { - $from[] = '/{{ add }}/'; - $to[] = ""; - $from[] = '/{{ rem }}/'; - $to[] = "\n"; - } - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-updateStatus-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ add }} - {{ rem }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainUpdateAuthinfo - */ - public function domainUpdateAuthinfo($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ authInfo }}/'; - $to[] = htmlspecialchars($params['authInfo']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-updateAuthinfo-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ authInfo }} - - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainUpdateDNSSEC - */ - public function domainUpdateDNSSEC($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - if ($params['command'] == 'add') { - $from[] = '/{{ add }}/'; - $to[] = " - - ".htmlspecialchars($params['keyTag_1'])." - ".htmlspecialchars($params['alg_1'])." - ".htmlspecialchars($params['digestType_1'])." - ".htmlspecialchars($params['digest_1'])." - - "; - $from[] = '/{{ rem }}/'; - $to[] = ""; - $from[] = '/{{ addrem }}/'; - $to[] = ""; - } else if ($params['command'] == 'rem') { - $from[] = '/{{ add }}/'; - $to[] = ""; - $from[] = '/{{ rem }}/'; - $to[] = " - - ".htmlspecialchars($params['keyTag_1'])." - ".htmlspecialchars($params['alg_1'])." - ".htmlspecialchars($params['digestType_1'])." - ".htmlspecialchars($params['digest_1'])." - - "; - $from[] = '/{{ addrem }}/'; - $to[] = ""; - } else if ($params['command'] == 'addrem') { - $from[] = '/{{ add }}/'; - $to[] = ""; - $from[] = '/{{ rem }}/'; - $to[] = ""; - $from[] = '/{{ addrem }}/'; - $to[] = " - - ".htmlspecialchars($params['keyTag_1'])." - ".htmlspecialchars($params['alg_1'])." - ".htmlspecialchars($params['digestType_1'])." - ".htmlspecialchars($params['digest_1'])." - - - - - ".htmlspecialchars($params['keyTag_2'])." - ".htmlspecialchars($params['alg_2'])." - ".htmlspecialchars($params['digestType_2'])." - ".htmlspecialchars($params['digest_2'])." - - "; - } - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-updateDNSSEC-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - - - {{ add }} - {{ rem }} - {{ addrem }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainTransfer - */ - public function domainTransfer($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - switch (htmlspecialchars($params['op'])) { - case 'request': - $from[] = '/{{ years }}/'; - $to[] = (int)($params['years']); - $from[] = '/{{ authInfoPw }}/'; - $to[] = htmlspecialchars($params['authInfoPw']); - $xmltype = 'req'; - break; - case 'query': - $from[] = '/{{ type }}/'; - $to[] = 'query'; - $xmltype = 'oth'; - break; - case 'cancel': - $from[] = '/{{ type }}/'; - $to[] = 'cancel'; - $xmltype = 'oth'; - break; - case 'reject': - $from[] = '/{{ type }}/'; - $to[] = 'reject'; - $xmltype = 'oth'; - break; - case 'approve': - $xmltype = 'apr'; - break; - default: - throw new EppException('Invalid value for transfer:op specified.'); - break; - } - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-transfer-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - if ($xmltype === 'req') { - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ years }} - - {{ authInfoPw }} - - - - {{ clTRID }} - - '); - - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->trnData; - $name = (string)$r->name; - $trStatus = (string)$r->trStatus; - $reID = (string)$r->reID; - $reDate = (string)$r->reDate; - $acID = (string)$r->acID; - $acDate = (string)$r->acDate; - $exDate = (string)$r->exDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'trStatus' => $trStatus, - 'reID' => $reID, - 'reDate' => $reDate, - 'acID' => $acID, - 'acDate' => $acDate, - 'exDate' => $exDate - ); - - } else if ($xmltype === 'apr') { - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - - '); - - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->Data; - $name = (string)$r->name; - $trStatus = (string)$r->trStatus; - $reID = (string)$r->reID; - $reDate = (string)$r->reDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'trStatus' => $trStatus, - 'reID' => $reID, - 'reDate' => $reDate - ); - - } else if ($xmltype === 'oth') { - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - - '); - - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - - } - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainCreate - */ - public function domainCreate($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ period }}/'; - $to[] = (int)($params['period']); - if (isset($params['nss'])) { - $text = ''; - foreach ($params['nss'] as $hostObj) { - $text .= '' . $hostObj . '' . "\n"; - } - $from[] = '/{{ hostObjs }}/'; - $to[] = $text; - } else { - $from[] = '/{{ hostObjs }}/'; - $to[] = ''; - } - $from[] = '/{{ registrant }}/'; - $to[] = htmlspecialchars($params['registrant']); - $text = ''; - foreach ($params['contacts'] as $contactType => $contactID) { - $text .= '' . $contactID . '' . "\n"; - } - $from[] = '/{{ contacts }}/'; - $to[] = $text; - $from[] = '/{{ authInfoPw }}/'; - $to[] = htmlspecialchars($params['authInfoPw']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-create-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ period }} - - {{ hostObjs }} - - {{ registrant }} - {{ contacts }} - - {{ authInfoPw }} - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->creData; - $name = (string)$r->name; - $crDate = (string)$r->crDate; - $exDate = (string)$r->exDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'crDate' => $crDate, - 'exDate' => $exDate - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainCreateDNSSEC - */ - public function domainCreateDNSSEC($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ period }}/'; - $to[] = (int)($params['period']); - if (isset($params['nss'])) { - $text = ''; - foreach ($params['nss'] as $hostObj) { - $text .= '' . $hostObj . '' . "\n"; - } - $from[] = '/{{ hostObjs }}/'; - $to[] = $text; - } else { - $from[] = '/{{ hostObjs }}/'; - $to[] = ''; - } - $from[] = '/{{ registrant }}/'; - $to[] = htmlspecialchars($params['registrant']); - $text = ''; - foreach ($params['contacts'] as $contactType => $contactID) { - $text .= '' . $contactID . '' . "\n"; - } - $from[] = '/{{ contacts }}/'; - $to[] = $text; - $from[] = '/{{ authInfoPw }}/'; - $to[] = htmlspecialchars($params['authInfoPw']); - if ($params['dnssec_records'] == 1) { - $from[] = '/{{ dnssec_data }}/'; - $to[] = " - ".htmlspecialchars($params['keyTag_1'])." - ".htmlspecialchars($params['alg_1'])." - ".htmlspecialchars($params['digestType_1'])." - ".htmlspecialchars($params['digest_1'])." - "; - } else if ($params['dnssec_records'] == 2) { - $from[] = '/{{ dnssec_data }}/'; - $to[] = " - ".htmlspecialchars($params['keyTag_1'])." - ".htmlspecialchars($params['alg_1'])." - ".htmlspecialchars($params['digestType_1'])." - ".htmlspecialchars($params['digest_1'])." - - - ".htmlspecialchars($params['keyTag_2'])." - ".htmlspecialchars($params['alg_2'])." - ".htmlspecialchars($params['digestType_2'])." - ".htmlspecialchars($params['digest_2'])." - "; - } - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-createDNSSEC-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ period }} - - {{ hostObjs }} - - {{ registrant }} - {{ contacts }} - - {{ authInfoPw }} - - - - - - {{ dnssec_data }} - - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->creData; - $name = (string)$r->name; - $crDate = (string)$r->crDate; - $exDate = (string)$r->exDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'crDate' => $crDate, - 'exDate' => $exDate - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainCreateClaims - */ - public function domainCreateClaims($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ period }}/'; - $to[] = (int)($params['period']); - if (isset($params['nss'])) { - $text = ''; - foreach ($params['nss'] as $hostObj) { - $text .= '' . $hostObj . '' . "\n"; - } - $from[] = '/{{ hostObjs }}/'; - $to[] = $text; - } else { - $from[] = '/{{ hostObjs }}/'; - $to[] = ''; - } - $from[] = '/{{ registrant }}/'; - $to[] = htmlspecialchars($params['registrant']); - $text = ''; - foreach ($params['contacts'] as $contactType => $contactID) { - $text .= '' . $contactID . '' . "\n"; - } - $from[] = '/{{ contacts }}/'; - $to[] = $text; - $from[] = '/{{ authInfoPw }}/'; - $to[] = htmlspecialchars($params['authInfoPw']); - $from[] = '/{{ noticeID }}/'; - $to[] = htmlspecialchars($params['noticeID']); - $from[] = '/{{ notAfter }}/'; - $to[] = htmlspecialchars($params['notAfter']); - $from[] = '/{{ acceptedDate }}/'; - $to[] = htmlspecialchars($params['acceptedDate']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-createClaims-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ period }} - - {{ hostObjs }} - - {{ registrant }} - {{ contacts }} - - {{ authInfoPw }} - - - - - claims - - {{ noticeID }} - {{ notAfter }} - {{ acceptedDate }} - - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->creData; - $name = (string)$r->name; - $crDate = (string)$r->crDate; - $exDate = (string)$r->exDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'crDate' => $crDate, - 'exDate' => $exDate - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainRenew - */ - public function domainRenew($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-renew-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->infData; - - $expDate = (string)$r->exDate; - $expDate = preg_replace("/^(\d+\-\d+\-\d+)\D.*$/", "$1", $expDate); - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ regperiod }}/'; - $to[] = htmlspecialchars($params['regperiod']); - $from[] = '/{{ expDate }}/'; - $to[] = htmlspecialchars($expDate); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-renew-' . $clTRID); - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - {{ expDate }} - {{ regperiod }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->renData; - $name = (string)$r->name; - $exDate = (string)$r->exDate; - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'name' => $name, - 'exDate' => $exDate - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainDelete - */ - public function domainDelete($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-delete-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainRestore - */ - public function domainRestore($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-restore-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - - - - - - - {{ clTRID }} - -'); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * domainReport - */ - public function domainReport($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ name }}/'; - $to[] = htmlspecialchars($params['domainname']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-domain-report-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - - {{ name }} - - - - - - - - Pre-delete registration data goes here. - Both XML and free text are allowed. - Post-restore registration data goes here. - Both XML and free text are allowed. - 2019-10-10T22:00:00.0Z - 2019-10-20T22:00:00.0Z - Registrant error. - This registrar has not restored the - Registered Name in order to assume the rights to use - or sell the Registered Name for itself or for any - third party. - The information in this report is - true to best of this registrars knowledge, and this - registrar acknowledges that intentionally supplying - false information in this report shall constitute an - incurable material breach of the - Registry-Registrar Agreement. - Supporting information goes - here. - - - - - {{ clTRID }} - - '); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * pollReq - */ - public function pollReq() - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-poll-req-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - {{ clTRID }} - - '); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - $messages = (int)($r->response->msgQ->attributes()->count ?? 0); - $last_id = (int)($r->response->msgQ->attributes()->id ?? 0); - $qDate = (string)($r->response->msgQ->qDate ?? ''); - $last_msg = (string)($r->response->msgQ->msg ?? ''); - - $return = array( - 'code' => $code, - 'msg' => $msg, - 'messages' => $messages, - 'last_id' => $last_id, - 'qDate' => $qDate, - 'last_msg' => $last_msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - /** - * pollAck - */ - public function pollAck($params = array()) - { - if (!$this->isLoggedIn) { - return array( - 'code' => 2002, - 'msg' => 'Command use error' - ); - } - - $return = array(); - try { - $from = $to = array(); - $from[] = '/{{ message }}/'; - $to[] = htmlspecialchars($params['msgID']); - $from[] = '/{{ clTRID }}/'; - $clTRID = str_replace('.', '', round(microtime(1), 3)); - $to[] = htmlspecialchars($this->prefix . '-poll-ack-' . $clTRID); - $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; - $to[] = ''; - $xml = preg_replace($from, $to, ' - - - - {{ clTRID }} - - '); - $r = $this->writeRequest($xml); - $code = (int)$r->response->result->attributes()->code; - $msg = (string)$r->response->result->msg; - - $return = array( - 'code' => $code, - 'msg' => $msg - ); - } catch (\Exception $e) { - $return = array( - 'error' => $e->getMessage() - ); - } - - return $return; - } - - public function _response_log($content) - { - $handle = fopen(dirname(__FILE__) . '/epp_response.log', 'a'); - ob_start(); - echo "\n==================================\n"; - ob_end_clean(); - fwrite($handle, $content); - fclose($handle); - } - - public function _request_log($content) - { - $handle = fopen(dirname(__FILE__) . '/epp_request.log', 'a'); - ob_start(); - echo "\n==================================\n"; - ob_end_clean(); - fwrite($handle, $content); - fclose($handle); - } -} diff --git a/eppSync.php b/eppSync.php index 5107103..6b4e234 100644 --- a/eppSync.php +++ b/eppSync.php @@ -1,28 +1,19 @@ prepare("SELECT * FROM tld_registrar WHERE registrar = :registrar"); - - // Bind the $registrar value to the :registrar parameter $stmt->bindValue(":registrar", $registrar); - - // Execute the prepared statement $stmt->execute(); - - // Fetch all rows from the result set $rows = $stmt->fetchAll(PDO::FETCH_ASSOC); $config = []; @@ -35,20 +26,20 @@ if (empty($config)) { - throw new Exception("Database cannot be accessed right now."); + exit("Database cannot be accessed right now.".PHP_EOL); } } catch(PDOException $e) { - echo "Database error: " . $e->getMessage(); + exit("Database error: " . $e->getMessage().PHP_EOL); } catch(Exception $e) { - echo "General error: " . $e->getMessage(); + exit("General error: " . $e->getMessage().PHP_EOL); } -function connectEpp(string $registry, $config) +function connectEpp($config) { try { @@ -62,8 +53,7 @@ function connectEpp(string $registry, $config) "prefix" => "tembo", ]); if (array_key_exists("error", $login)) { - echo "Login Error: " . $login["error"] . PHP_EOL; - exit(); + exit("Login Error: " . $login["error"]. PHP_EOL); } else { @@ -73,7 +63,7 @@ function connectEpp(string $registry, $config) } catch(EppException $e) { - return "Error : " . $e->getMessage(); + exit("Error : " . $e->getMessage().PHP_EOL); } } @@ -84,20 +74,38 @@ function connectEpp(string $registry, $config) $stmt->execute(); $domains = $stmt->fetchAll(PDO::FETCH_ASSOC); - $epp = connectEpp("generic", $config); + $epp = connectEpp($config); foreach ($domains as $domainRow) { - // Combine sld and tld into a single domain name $domain = $domainRow['sld'] . $domainRow['tld']; - $params = ["domainname" => $domain]; $domainInfo = $epp->domainInfo($params); - if (array_key_exists("error", $domainInfo)) { - echo "DomainInfo Error: " . $domainInfo["error"] . " (" . $domain . ")" . PHP_EOL; + if (array_key_exists("error", $domainInfo) || (isset($domainInfo['code']) && $domainInfo['code'] == 2303)) { + if (strpos($domainInfo["error"], "Domain does not exist") !== false || (isset($domainInfo['code']) && $domainInfo['code'] == 2303)) { + $stmt = $pdo->prepare('DELETE FROM service_domain WHERE sld = :sld AND tld = :tld'); + $stmt->bindValue(':sld', $domainRow['sld']); + $stmt->bindValue(':tld', $domainRow['tld']); + $stmt->execute(); + } + $stmt = $pdo->prepare('SELECT id FROM service_domain WHERE sld = :sld AND tld = :tld'); + $stmt->bindValue(':sld', $domainRow['sld']); + $stmt->bindValue(':tld', $domainRow['tld']); + $stmt->execute(); + $serviceDomain = $stmt->fetch(PDO::FETCH_ASSOC); + if ($serviceDomain) { + $serviceId = $serviceDomain['id']; + $stmt = $pdo->prepare('UPDATE client_order SET canceled_at = :canceled_at, status = :status, reason = :reason WHERE service_id = :service_id'); + $stmt->bindValue(':canceled_at', date('Y-m-d H:i:s')); + $stmt->bindValue(':status', 'cancelled'); + $stmt->bindValue(':reason', 'domain deleted'); + $stmt->bindValue(':service_id', $serviceId); + $stmt->execute(); + } + echo $domainInfo["error"] . " (" . $domain . ")" . PHP_EOL; continue; } - + $ns = $domainInfo['ns']; $ns1 = isset($ns[1]) ? $ns[1] : null; @@ -126,30 +134,111 @@ function connectEpp(string $registry, $config) $locked = 0; } - // Prepare the UPDATE statement - $stmt = $pdo->prepare('UPDATE service_domain SET ns1 = :ns1, ns2 = :ns2, ns3 = :ns3, ns4 = :ns4, expires_at = :expires_at, locked = :locked, transfer_code = :transfer_code WHERE sld = :sld AND tld = :tld'); + $sqlCheck = 'SELECT COUNT(*) FROM extension WHERE name = :name AND status = :status'; + $stmtCheck = $pdo->prepare($sqlCheck); + $stmtCheck->bindValue(':name', 'registrar'); + $stmtCheck->bindValue(':status', 'installed'); + $stmtCheck->execute(); + $count = $stmtCheck->fetchColumn(); - // Bind the values to the statement + // Prepare the UPDATE statement + $stmt = $pdo->prepare('UPDATE service_domain SET ns1 = :ns1, ns2 = :ns2, ns3 = :ns3, ns4 = :ns4, expires_at = :expires_at, locked = :locked, synced_at = :synced_at, transfer_code = :transfer_code WHERE sld = :sld AND tld = :tld'); $stmt->bindValue(':ns1', $ns1); $stmt->bindValue(':ns2', $ns2); $stmt->bindValue(':ns3', $ns3); $stmt->bindValue(':ns4', $ns4); $stmt->bindValue(':expires_at', $formattedExDate); $stmt->bindValue(':locked', $locked); + $stmt->bindValue(':synced_at', date('Y-m-d H:i:s')); $stmt->bindValue(':transfer_code', $domainInfo["authInfo"]); $stmt->bindValue(':sld', $domainRow['sld']); $stmt->bindValue(':tld', $domainRow['tld']); - - // Execute the statement $stmt->execute(); - $sqlCheck = 'SELECT COUNT(*) FROM extension WHERE name = :name AND status = :status'; - $stmtCheck = $pdo->prepare($sqlCheck); - $stmtCheck->bindValue(':name', 'registrar'); - $stmtCheck->bindValue(':status', 'installed'); - $stmtCheck->execute(); - $count = $stmtCheck->fetchColumn(); + $stmt = $pdo->prepare('SELECT id FROM service_domain WHERE sld = :sld AND tld = :tld'); + $stmt->bindValue(':sld', $domainRow['sld']); + $stmt->bindValue(':tld', $domainRow['tld']); + $stmt->execute(); + $serviceDomain = $stmt->fetch(PDO::FETCH_ASSOC); + if ($serviceDomain) { + $serviceId = $serviceDomain['id']; + $stmt = $pdo->prepare('UPDATE client_order SET expires_at = :expires_at WHERE service_id = :service_id'); + $stmt->bindValue(':expires_at', $formattedExDate); + $stmt->bindValue(':service_id', $serviceId); + $stmt->execute(); + + if ($count > 0) { + $stmt = $pdo->prepare('SELECT registrant_contact_id FROM domain_meta WHERE domain_id = :id'); + $stmt->bindValue(':id', $serviceId); + $stmt->execute(); + $result = $stmt->fetch(PDO::FETCH_ASSOC); + $registrant_contact_id = $result['registrant_contact_id']; + + $contact_params = ["contact" => $registrant_contact_id]; + $contactInfo = $epp->contactInfo($contact_params); + + if (array_key_exists('error', $contactInfo)) + { + echo 'ContactInfo Error: ' . $contactInfo['error'] . PHP_EOL; + } + else + { + try { + // Prepare the UPDATE statement + $stmt = $pdo->prepare(' + UPDATE service_domain + SET + contact_email = :contact_email, + contact_company = :contact_company, + contact_first_name = :contact_first_name, + contact_last_name = :contact_last_name, + contact_address1 = :contact_address1, + contact_address2 = :contact_address2, + contact_city = :contact_city, + contact_state = :contact_state, + contact_postcode = :contact_postcode, + contact_country = :contact_country, + contact_phone_cc = :contact_phone_cc, + contact_phone = :contact_phone + WHERE id = :id + '); + + // Split name into first and last names + $nameParts = explode(' ', $contactInfo['name']); + $contactFirstName = array_shift($nameParts); // First part of the name + $contactLastName = implode(' ', $nameParts); // Remaining parts as the last name + + // Split phone into country code and number + $phoneParts = explode('.', $contactInfo['voice']); + $contactPhoneCC = isset($phoneParts[0]) ? $phoneParts[0] : null; + $contactPhone = isset($phoneParts[1]) ? $phoneParts[1] : null; + + // Bind values, setting them to NULL if they are empty + $stmt->bindValue(':contact_email', !empty($contactInfo['email']) ? $contactInfo['email'] : null); + $stmt->bindValue(':contact_company', !empty($contactInfo['org']) ? $contactInfo['org'] : null); + $stmt->bindValue(':contact_first_name', !empty($contactFirstName) ? $contactFirstName : null); + $stmt->bindValue(':contact_last_name', !empty($contactLastName) ? $contactLastName : null); + $stmt->bindValue(':contact_address1', !empty($contactInfo['street1']) ? $contactInfo['street1'] : null); + $stmt->bindValue(':contact_address2', !empty($contactInfo['street2']) ? $contactInfo['street2'] : null); + $stmt->bindValue(':contact_city', !empty($contactInfo['city']) ? $contactInfo['city'] : null); + $stmt->bindValue(':contact_state', !empty($contactInfo['state']) ? $contactInfo['state'] : null); + $stmt->bindValue(':contact_postcode', !empty($contactInfo['postal']) ? $contactInfo['postal'] : null); + $stmt->bindValue(':contact_country', !empty($contactInfo['country']) ? $contactInfo['country'] : null); + $stmt->bindValue(':contact_phone_cc', !empty($contactPhoneCC) ? $contactPhoneCC : null); + $stmt->bindValue(':contact_phone', !empty($contactPhone) ? $contactPhone : null); + $stmt->bindValue(':id', $serviceId); + $stmt->execute(); + + echo "Update successful for contact: ".$contactInfo['id'].PHP_EOL; + + } catch (PDOException $e) { + exit("Database error: " . $e->getMessage().PHP_EOL); + } + } + } + } + if ($count > 0) { $selectStmt = $pdo->prepare('SELECT id FROM service_domain WHERE sld = :sld AND tld = :tld LIMIT 1'); $selectStmt->bindValue(':sld', $domainRow['sld']); @@ -217,7 +306,509 @@ function connectEpp(string $registry, $config) $logout = $epp->logout(); echo "Logout Result: " . $logout["code"] . ": " . $logout["msg"][0] . PHP_EOL; } catch (PDOException $e) { - echo "Database error: " . $e->getMessage(); + exit("Database error: " . $e->getMessage().PHP_EOL); } catch(EppException $e) { - echo "Error: ", $e->getMessage(); + exit("Error: " . $e->getMessage().PHP_EOL); +} + +// Mini EPP Clinet Class +class eppClient +{ + private $resource; + private $isLoggedIn; + private $prefix; + + public function __construct() + { + if (!extension_loaded('SimpleXML')) { + exit('PHP extension SimpleXML is not loaded.'.PHP_EOL); + } + } + + /** + * connect + */ + public function connect($params = array()) + { + $host = (string)$params['host']; + $port = (int)$params['port']; + $timeout = (int)$params['timeout']; + $tls = (string)$params['tls']; + $bind = (string)$params['bind']; + $bindip = (string)$params['bindip']; + if ($tls !== '1.3' && $tls !== '1.2' && $tls !== '1.1') { + exit('Invalid TLS version specified.'.PHP_EOL); + } + $opts = array( + 'ssl' => array( + 'verify_peer' => (bool)$params['verify_peer'], + 'verify_peer_name' => (bool)$params['verify_peer_name'], + 'verify_host' => (bool)$params['verify_host'], + 'cafile' => (string)$params['cafile'], + 'local_cert' => (string)$params['local_cert'], + 'local_pk' => (string)$params['local_pk'], + 'passphrase' => (string)$params['passphrase'], + 'allow_self_signed' => (bool)$params['allow_self_signed'], + 'min_tls_version' => $tls + ) + ); + if ($bind) { + $opts['socket'] = array('bindto' => $bindip); + } + $context = stream_context_create($opts); + $this->resource = stream_socket_client("tls://{$host}:{$port}", $errno, $errmsg, $timeout, STREAM_CLIENT_CONNECT, $context); + if (!$this->resource) { + exit("Cannot connect to server '{$host}': {$errmsg}".PHP_EOL); + } + + return $this->readResponse(); + } + + /** + * readResponse + */ + public function readResponse() + { + $hdr = stream_get_contents($this->resource, 4); + if ($hdr === false) { + exit('Connection appears to have closed.'.PHP_EOL); + } + if (strlen($hdr) < 4) { + exit('Failed to read header from the connection.'.PHP_EOL); + } + $unpacked = unpack('N', $hdr); + $xml = fread($this->resource, ($unpacked[1] - 4)); + $xml = preg_replace('/>\n<", $xml); + $this->_response_log($xml); + return $xml; + } + + /** + * writeRequest + */ + public function writeRequest($xml) + { + $this->_request_log($xml); + if (fwrite($this->resource, pack('N', (strlen($xml) + 4)) . $xml) === false) { + exit('Error writing to the connection.'.PHP_EOL); + } + $xml_string = $this->readResponse(); + libxml_use_internal_errors(true); + + $r = simplexml_load_string($xml_string, 'SimpleXMLElement', LIBXML_DTDLOAD | LIBXML_NOENT); + if ($r instanceof SimpleXMLElement) { + $r->registerXPathNamespace('e', 'urn:ietf:params:xml:ns:epp-1.0'); + $r->registerXPathNamespace('xsi', 'http://www.w3.org/2001/XMLSchema-instance'); + $r->registerXPathNamespace('domain', 'urn:ietf:params:xml:ns:domain-1.0'); + $r->registerXPathNamespace('contact', 'urn:ietf:params:xml:ns:contact-1.0'); + $r->registerXPathNamespace('host', 'urn:ietf:params:xml:ns:host-1.0'); + $r->registerXPathNamespace('rgp', 'urn:ietf:params:xml:ns:rgp-1.0'); + } + if (isset($r->response) && $r->response->result->attributes()->code >= 2000) { + echo $r->response->result->msg.PHP_EOL; + } + return $r; + } + + /** + * disconnect + */ + public function disconnect() + { + if (!fclose($this->resource)) { + exit('Error closing the connection.'.PHP_EOL); + } + $this->resource = null; + } + + /** + * wrapper for functions + */ + public function __call($func, $args) + { + if (!function_exists($func)) { + exit("Call to undefined method Epp::$func().".PHP_EOL); + } + + if ($func === 'connect') { + try { + $result = call_user_func_array($func, $args); + } catch (\ErrorException $e) { + exit($e->getMessage().PHP_EOL); + } + + if (!is_resource($this->resource)) { + exit('An error occured while trying to connect to EPP server.'.PHP_EOL); + } + + $result = null; + } elseif (!is_resource($this->resource)) { + exit('Not connected to EPP server.'.PHP_EOL); + } else { + array_unshift($args, $this->resource); + try { + $result = call_user_func_array($func, $args); + } catch (\ErrorException $e) { + exit($e->getMessage().PHP_EOL); + } + } + + return $result; + } + + /** + * login + */ + public function login($params = array()) + { + $return = array(); + try { + $from = $to = array(); + $from[] = '/{{ clID }}/'; + $to[] = htmlspecialchars($params['clID']); + $from[] = '/{{ pwd }}/'; + $to[] = htmlspecialchars($params['pw']); + if (isset($params['newpw']) && !empty($params['newpw'])) { + $from[] = '/{{ newpw }}/'; + $to[] = PHP_EOL . ' ' . htmlspecialchars($params['newpw']) . ''; + } else { + $from[] = '/{{ newpw }}/'; + $to[] = ''; + } + $from[] = '/{{ clTRID }}/'; + $microtime = str_replace('.', '', round(microtime(1), 3)); + $to[] = htmlspecialchars($params['prefix'] . '-login-' . $microtime); + $xml = preg_replace($from, $to, ' + + + + {{ clID }} + {{ pwd }}{{ newpw }} + + 1.0 + en + + + urn:ietf:params:xml:ns:domain-1.0 + urn:ietf:params:xml:ns:contact-1.0 + urn:ietf:params:xml:ns:host-1.0 + + urn:ietf:params:xml:ns:secDNS-1.1 + urn:ietf:params:xml:ns:rgp-1.0 + + + + {{ clTRID }} + +'); + $r = $this->writeRequest($xml); + $code = (int)$r->response->result->attributes()->code; + if ($code == 1000) { + $this->isLoggedIn = true; + $this->prefix = $params['prefix']; + } + + $return = array( + 'code' => $code, + 'msg' => $r->response->result->msg + ); + } catch (\Exception $e) { + $return = array( + 'error' => $e->getMessage() + ); + } + + return $return; + } + + /** + * logout + */ + public function logout($params = array()) + { + if (!$this->isLoggedIn) { + return array( + 'code' => 2002, + 'msg' => 'Command use error' + ); + } + + $return = array(); + try { + $from = $to = array(); + $from[] = '/{{ clTRID }}/'; + $microtime = str_replace('.', '', round(microtime(1), 3)); + $to[] = htmlspecialchars($this->prefix . '-logout-' . $microtime); + $xml = preg_replace($from, $to, ' + + + + {{ clTRID }} + +'); + $r = $this->writeRequest($xml); + $code = (int)$r->response->result->attributes()->code; + if ($code == 1500) { + $this->isLoggedIn = false; + } + + $return = array( + 'code' => $code, + 'msg' => $r->response->result->msg + ); + } catch (\Exception $e) { + $return = array( + 'error' => $e->getMessage() + ); + } + + return $return; + } + + /** + * domainInfo + */ + public function domainInfo($params = array()) + { + if (!$this->isLoggedIn) { + return array( + 'code' => 2002, + 'msg' => 'Command use error' + ); + } + + $return = array(); + try { + $from = $to = array(); + $from[] = '/{{ domainname }}/'; + $to[] = htmlspecialchars($params['domainname']); + $from[] = '/{{ authInfo }}/'; + $authInfo = (isset($params['authInfoPw']) ? "\n\n" : ''); + $to[] = $authInfo; + $from[] = '/{{ clTRID }}/'; + $microtime = str_replace('.', '', round(microtime(1), 3)); + $to[] = htmlspecialchars($this->prefix . '-domain-info-' . $microtime); + $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; + $to[] = ''; + $xml = preg_replace($from, $to, ' + + + + + {{ domainname }} + {{ authInfo }} + + + {{ clTRID }} + +'); + $r = $this->writeRequest($xml); + $code = (int)$r->response->result->attributes()->code; + $msg = (string)$r->response->result->msg; + $r = $r->response->resData->children('urn:ietf:params:xml:ns:domain-1.0')->infData; + $name = (string)$r->name; + $roid = (string)$r->roid; + $status = array(); + $i = 0; + foreach ($r->status as $e) { + $i++; + $status[$i] = (string)$e->attributes()->s; + } + $registrant = (string)$r->registrant; + $contact = array(); + $i = 0; + foreach ($r->contact as $e) { + $i++; + $contact[$i]['type'] = (string)$e->attributes()->type; + $contact[$i]['id'] = (string)$e; + } + $ns = array(); + $i = 0; + if (isset($r->ns->hostObj) && (is_array($r->ns->hostObj) || is_object($r->ns->hostObj))) { + foreach ($r->ns->hostObj as $hostObj) { + $i++; + $ns[$i] = (string)$hostObj; + } + } else { + $ns = []; + } + $host = array(); + $i = 0; + foreach ($r->host as $hostname) { + $i++; + $host[$i] = (string)$hostname; + } + $clID = (string)$r->clID; + $crID = (string)$r->crID; + $crDate = (string)$r->crDate; + $upID = (string)$r->upID; + $upDate = (string)$r->upDate; + $exDate = (string)$r->exDate; + $trDate = (string)$r->trDate; + $authInfo = (string)$r->authInfo->pw; + + $return = array( + 'code' => $code, + 'msg' => $msg, + 'name' => $name, + 'roid' => $roid, + 'status' => $status, + 'registrant' => $registrant, + 'contact' => $contact, + 'ns' => $ns, + 'host' => $host, + 'clID' => $clID, + 'crID' => $crID, + 'crDate' => $crDate, + 'upID' => $upID, + 'upDate' => $upDate, + 'exDate' => $exDate, + 'trDate' => $trDate, + 'authInfo' => $authInfo + ); + } catch (\Exception $e) { + $return = array( + 'error' => $e->getMessage() + ); + } + + return $return; + } + + /** + * contactInfo + */ + public function contactInfo($params = array()) + { + if (!$this->isLoggedIn) { + return array( + 'code' => 2002, + 'msg' => 'Command use error' + ); + } + + $return = array(); + try { + $from = $to = array(); + $from[] = '/{{ id }}/'; + $to[] = htmlspecialchars($params['contact']); + $from[] = '/{{ authInfo }}/'; + $authInfo = (isset($params['authInfoPw']) ? "\n\n" : ''); + $to[] = $authInfo; + $from[] = '/{{ clTRID }}/'; + $microtime = str_replace('.', '', round(microtime(1), 3)); + $to[] = htmlspecialchars($this->prefix . '-contact-info-' . $microtime); + $from[] = "/<\w+:\w+>\s*<\/\w+:\w+>\s+/ims"; + $to[] = ''; + $xml = preg_replace($from, $to, ' + + + + + {{ id }} + {{ authInfo }} + + + {{ clTRID }} + +'); + $r = $this->writeRequest($xml); + $code = (int)$r->response->result->attributes()->code; + $msg = (string)$r->response->result->msg; + $r = $r->response->resData->children('urn:ietf:params:xml:ns:contact-1.0')->infData[0]; + + foreach ($r->postalInfo as $e) { + $name = (string)$e->name; + $org = (string)$e->org; + $street1 = $street2 = $street3 = ''; + for ($i = 0; $i <= 2; $i++) { + ${'street' . ($i + 1)} = (string)$e->addr->street[$i]; + } + $city = (string)$e->addr->city; + $state = (string)$e->addr->sp; + $postal = (string)$e->addr->pc; + $country = (string)$e->addr->cc; + } + $id = (string)$r->id; + $status = array(); + $i = 0; + foreach ($r->status as $e) { + $i++; + $status[$i] = (string)$e->attributes()->s; + } + $roid = (string)$r->roid; + $voice = (string)$r->voice; + $fax = (string)$r->fax; + $email = (string)$r->email; + $clID = (string)$r->clID; + $crID = (string)$r->crID; + $crDate = (string)$r->crDate; + $upID = (string)$r->upID; + $upDate = (string)$r->upDate; + $authInfo = (string)$r->authInfo->pw; + + $return = array( + 'id' => $id, + 'roid' => $roid, + 'code' => $code, + 'status' => $status, + 'msg' => $msg, + 'name' => $name, + 'org' => $org, + 'street1' => $street1, + 'street2' => $street2, + 'street3' => $street3, + 'city' => $city, + 'state' => $state, + 'postal' => $postal, + 'country' => $country, + 'voice' => $voice, + 'fax' => $fax, + 'email' => $email, + 'clID' => $clID, + 'crID' => $crID, + 'crDate' => $crDate, + 'upID' => $upID, + 'upDate' => $upDate, + 'authInfo' => $authInfo + ); + } catch (\Exception $e) { + $return = array( + 'error' => $e->getMessage() + ); + } + + return $return; + } + + public function _response_log($content) + { + $handle = fopen(dirname(__FILE__) . '/data/log/epp_response.log', 'a'); + ob_start(); + echo "\n==================================\n"; + ob_end_clean(); + fwrite($handle, $content); + fclose($handle); + } + + public function _request_log($content) + { + $handle = fopen(dirname(__FILE__) . '/data/log/epp_request.log', 'a'); + ob_start(); + echo "\n==================================\n"; + ob_end_clean(); + fwrite($handle, $content); + fclose($handle); + } } diff --git a/install_epp_module.sh b/install_epp_module.sh index cc07801..f259eda 100644 --- a/install_epp_module.sh +++ b/install_epp_module.sh @@ -27,11 +27,6 @@ sed -i "s/Registrar_Adapter_EPP/Registrar_Adapter_${safe_registry_name}/g" "$fos # Move and rename eppSync.php mv /tmp/fossbilling-epp-rfc/eppSync.php "$fossbilling_path/${safe_registry_name}Sync.php" -# Check if eppClient.php exists and move if not -if [ ! -f "$fossbilling_path/eppClient.php" ]; then - mv /tmp/fossbilling-epp-rfc/eppClient.php "$fossbilling_path/" -fi - # Edit the renamed eppSync.php sed -i "s/\$registrar = \"Epp\";/\$registrar = \"${safe_registry_name}\";/g" "$fossbilling_path/${safe_registry_name}Sync.php"