query('select code from :table_templates_boxes where modules_group = "payment"'); $Qmodules->bindTable(':table_templates_boxes', TABLE_TEMPLATES_BOXES); $Qmodules->setCache('modules-payment'); $Qmodules->execute(); while ($Qmodules->next()) { $this->_modules[] = $Qmodules->value('code'); } $Qmodules->freeResult(); if (empty($this->_modules) === false) { if ((empty($module) === false) && in_array($module, $this->_modules)) { $this->_modules = array($module); $this->selected_module = 'osC_Payment_' . $module; } $osC_Language->load('modules-payment'); foreach ($this->_modules as $modules) { include('includes/modules/payment/' . $modules . '.' . substr(basename(__FILE__), (strrpos(basename(__FILE__), '.')+1))); $module_class = 'osC_Payment_' . $modules; $GLOBALS[$module_class] = new $module_class(); } usort($this->_modules, array('osC_Payment', '_usortModules')); if ( (tep_not_null($module)) && (in_array($module, $this->_modules)) && (isset($GLOBALS['osC_Payment_' . $module]->form_action_url)) ) { $this->form_action_url = $GLOBALS['osC_Payment_' . $module]->form_action_url; } } } // class methods function sendTransactionToGateway($url, $parameters, $header='', $method='post') { if (empty($header) || (is_array($header) === false)) { $header = array(); } $result = ''; $server = parse_url($url); if (isset($server['port']) === false) { $server['port'] = ($server['scheme'] == 'https') ? 443 : 80; } if (isset($server['path']) === false) { $server['path'] = '/'; } if (isset($server['user']) && isset($server['pass'])) { $header[] = 'Authorization: Basic ' . base64_encode($server['user'] . ':' . $server['pass']); } $curl = curl_init($server['scheme'] . '://' . $server['host'] . $server['path'] . (isset($server['query']) ? '?' . $server['query'] : '')); curl_setopt($curl, CURLOPT_PORT, $server['port']); if (empty($header) === false) { curl_setopt($curl, CURLOPT_HTTPHEADER, $header); } curl_setopt($curl, CURLOPT_HEADER, 0); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); curl_setopt($curl, CURLOPT_FORBID_REUSE, 1); curl_setopt($curl, CURLOPT_FRESH_CONNECT, 1); curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $parameters); $result = curl_exec($curl); curl_close($curl); /* exec('/usr/bin/curl -d ' . escapeshellarg($parameters) . ' "' . $server['scheme'] . '://' . $server['host'] . $server['path'] . (isset($server['query']) ? '?' . $server['query'] : '') . '" -P ' . $server['port'] . ' -k ' . (empty($header) === false ? '-H ' . escapeshellarg(implode("\r\n", $header)) : ''), $result); $result = implode("\n", $result); */ /* if ($fp = @fsockopen(($server['scheme'] == 'https' ? 'ssl' : $server['scheme']) . '://' . $server['host'], $server['port'])) { @fputs($fp, 'POST ' . $server['path'] . (isset($server['query']) ? '?' . $server['query'] : '') . ' HTTP/1.1' . "\r\n" . 'Host: ' . $server['host'] . "\r\n" . 'Content-type: application/x-www-form-urlencoded' . "\r\n" . 'Content-length: ' . strlen($parameters) . "\r\n" . (empty($header) === false ? implode("\r\n", $header) . "\r\n" : '') . 'Connection: close' . "\r\n\r\n" . $parameters . "\r\n\r\n"); $result = @stream_get_contents($fp); @fclose($fp); $result = trim(substr($result, strpos($result, "\r\n\r\n", strpos(strtolower($result), 'content-length:')))); } */ return $result; } function getCode() { return $this->_code; } function getTitle() { return $this->_title; } function getDescription() { return $this->_description; } function getMethodTitle() { return $this->_method_title; } function isEnabled() { return $this->_status; } function getSortOrder() { return $this->_sort_order; } /* The following method is needed in the checkout_confirmation.php page due to a chicken and egg problem with the payment class and order class. The payment modules needs the order destination data for the dynamic status feature, and the order class needs the payment module title. The following method is a work-around to implementing the method in all payment modules available which would break the modules in the contributions section. This should be looked into again post 2.2. */ function update_status() { if (is_array($this->_modules)) { if (isset($GLOBALS[$this->selected_module]) && is_object($GLOBALS[$this->selected_module])) { if (method_exists($GLOBALS[$this->selected_module], 'update_status')) { $GLOBALS[$this->selected_module]->update_status(); } } } } function javascript_validation() { global $osC_Language; $js = ''; if (is_array($this->_modules)) { $js = '' . "\n"; } return $js; } function selection() { $selection_array = array(); foreach ($this->_modules as $module) { if ($GLOBALS['osC_Payment_' . $module]->isEnabled()) { $selection = $GLOBALS['osC_Payment_' . $module]->selection(); if (is_array($selection)) $selection_array[] = $selection; } } return $selection_array; } function pre_confirmation_check() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { $GLOBALS[$this->selected_module]->pre_confirmation_check(); } } } function confirmation() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { return $GLOBALS[$this->selected_module]->confirmation(); } } } function process_button() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { return $GLOBALS[$this->selected_module]->process_button(); } } } function before_process() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { return $GLOBALS[$this->selected_module]->before_process(); } } } function after_process() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { return $GLOBALS[$this->selected_module]->after_process(); } } } function get_error() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { return $GLOBALS[$this->selected_module]->get_error(); } } } function hasActionURL() { if (is_array($this->_modules)) { if (is_object($GLOBALS[$this->selected_module]) && $GLOBALS[$this->selected_module]->isEnabled()) { if (isset($GLOBALS[$this->selected_module]->form_action_url) && (empty($GLOBALS[$this->selected_module]->form_action_url) === false)) { return true; } } } return false; } function getActionURL() { return $GLOBALS[$this->selected_module]->form_action_url; } function hasActive() { static $has_active; if (isset($has_active) === false) { $has_active = false; foreach ($this->_modules as $module) { if ($GLOBALS['osC_Payment_' . $module]->isEnabled()) { $has_active = true; break; } } } return $has_active; } function numberOfActive() { static $active; if (isset($active) === false) { $active = 0; foreach ($this->_modules as $module) { if ($GLOBALS['osC_Payment_' . $module]->isEnabled()) { $active++; } } } return $active; } function _usortModules($a, $b) { if ($GLOBALS['osC_Payment_' . $a]->getSortOrder() == $GLOBALS['osC_Payment_' . $b]->getSortOrder()) { return strnatcasecmp($GLOBALS['osC_Payment_' . $a]->getTitle(), $GLOBALS['osC_Payment_' . $a]->getTitle()); } return ($GLOBALS['osC_Payment_' . $a]->getSortOrder() < $GLOBALS['osC_Payment_' . $b]->getSortOrder()) ? -1 : 1; } } ?>