* @package AgileBill * @version 1.4.93 */ /* * Vars available from server config (available in your heartinternet.co.uk Reseller Control Centre: * * authcode * * * Vars from service config: * * package * */ class plgn_prov_HEARTINTERNET { function plgn_prov_HEARTINTERNET() { $this->name = 'HEARTINTERNET'; $this->task_based = false; $this->remote_based = true; } # add new service function p_new() { # get the common server class and set login details $this->login['username'] = 'Defined by Heart Internet'; $this->login['password'] = 'Defined by Heart Internet'; # get ip address $this->ip = 'Defined by Heart Internet'; # Set the post vars: $url = "https://customer.heartinternet.co.uk/addpack.cgi". "?authcode={$this->server_cfg['authcode']};". "email={$this->account['email']};". "M_domain={$this->service['domain_name']}.{$this->service['domain_tld']};". "M_typeid={$this->plugin_data['package']};". "status=Y"; # Connect & get response: $result = $this->connect($url, '25'); # Check the response & Debug if($this->server['debug']) echo "
 ". print_r($result) ." 
"; if(!empty($result)) return true; else return false; } # edit service (must be performed manually) function p_edit() { return true; } # activate service (must be performed manually) function p_inactive() { return true; } # deactivate service (must be performed manually) function p_active() { return true; } # delete service (must be performed manually) function p_delete() { return true; } # construct echo all updates function p_one($id) { global $C_debug; # Get the service details $db = &DB(); $sql = 'SELECT * FROM ' . AGILE_DB_PREFIX . 'service WHERE id = ' . $db->qstr( $id ) . ' AND site_id = ' . $db->qstr(DEFAULT_SITE); $rs = $db->Execute($sql); if($rs->RecordCount() == 0) { return false; } $this->service = $rs->fields; $this->service_id = $rs->fields['id']; @$this->plugin_data = unserialize($this->service['host_provision_plugin_data']); # Get the account details $sql = 'SELECT * FROM ' . AGILE_DB_PREFIX . 'account WHERE id = ' . $db->qstr( $this->service['account_id'] ) . ' AND site_id = ' . $db->qstr(DEFAULT_SITE); $acct = $db->Execute($sql); $this->account = $acct->fields; # Get the server details $db = &DB(); $sql = 'SELECT * FROM ' . AGILE_DB_PREFIX . 'host_server WHERE id = ' . $db->qstr( $this->service['host_server_id'] ) . ' AND site_id = ' . $db->qstr(DEFAULT_SITE); $rs = $db->Execute($sql); if (@$rs->RecordCount() == 0) { return false; } else { $this->server = $rs->fields; @$this->server_cfg = unserialize($rs->fields['provision_plugin_data']); } # determine the correct action switch ($this->service['queue']) { # new case 'new': $result = $this->p_new(); # send the user the details #include_once(PATH_MODULES.'email_template/email_template.inc.php'); #$email = new email_template; #$email->send('host_new_user', $this->account['id'], $rs->fields['id'], '', ''); break; # active case 'active': $result = $this->p_active(); break; # inactive case 'inactive': $result = $this->p_inactive(); break; # edit case 'edit': if ($this->service['active'] == 1 ) $result = $this->p_active(); else $result = $this->p_inactive(); break; # delete case 'delete': $result = $this->p_delete(); break; } # update service record if(@$result) { # update $db = &DB(); $sql = 'UPDATE ' . AGILE_DB_PREFIX . 'service SET queue = ' . $db->qstr( 'none' ) . ', date_last = ' . $db->qstr( time() ) . ' WHERE id = ' . $db->qstr( $this->service_id ) . ' AND site_id = ' . $db->qstr(DEFAULT_SITE); $upd = $db->Execute($sql); } else { # error log $C_debug->error($this->name.'.php', $this->service['queue'], $this->service['queue'] . ' For service id '. $this->service_id . ' Failed!'); } } /* * Curl connect */ function connect($url,$timeout=false) { $ch = curl_init(); if($timeout != false) curl_setopt($ch, CURLOPT_TIMEOUT, $timeout); curl_setopt($ch, CURLOPT_URL, $url ); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); $data = curl_exec ($ch); curl_close ($ch); return $data; } } ?>