extract($aTransaction); if ($plg_aut_Cleared) { // If this one already cleared do not submit it again. continue; } $echoPHP->set_EchoServer("https://wwws.echo-inc.com/scripts/INR200.EXE"); $echoPHP->set_merchant_echo_id($EchoAccount); $echoPHP->set_merchant_pin($EchoPin); $echoPHP->set_grand_total($plg_amount); $echoPHP->set_billing_phone($phone); $echoPHP->set_billing_address1($address1); $echoPHP->set_billing_address2($address2); $echoPHP->set_billing_city($city); $echoPHP->set_billing_state($state); $echoPHP->set_billing_zip($zip); $echoPHP->set_billing_country($country); $echoPHP->set_billing_email($email); $echoPHP->set_billing_ip_address($REMOTE_ADDR); $echoPHP->set_order_type("S"); $echoPHP->set_cnp_recurring("Y"); if ($dep_Type == "CreditCard") { $echoPHP->set_billing_first_name($firstName); $echoPHP->set_billing_last_name($lastName); $echoPHP->set_cc_number($creditCard); $echoPHP->set_ccexp_month($expMonth); $echoPHP->set_ccexp_year($expYear); $echoPHP->set_transaction_type("EV"); // $echoPHP->set_cnp_security(3333); // The three-digit MasterCard (CVC2) or VISA (CVV2) or the four-digit Discover (CID) // or AMEX card-not-present security code. } else { // check payment info if supplied...
function bill_checkout($amount, $invoice, $currency_iso, $acct_fields, $total_recurring = false, $recurr_bill_arr = false) { # Validate currency if (!$this->validate_currency($currency_iso)) { return false; } $ret = false; if (!$this->validate_card_details($ret)) { return false; } # Get the country $country = $this->getCountry('three_code', $acct_fields["country_id"]); if ($this->cfg['mode'] = "0") { $test = "F"; } else { $test = "T"; } include_once PATH_PLUGINS . 'checkout/CLASS_ECHO/echophp.class'; $echoPHP = new EchoPHP(); $echoPHP->set_order_type("S"); $echoPHP->set_debug($test); $echoPHP->set_EchoServer($this->host . '' . $this->url); $echoPHP->set_transaction_type($this->cfg["type"]); $echoPHP->set_merchant_echo_id($this->cfg["id"]); $echoPHP->set_merchant_pin($this->cfg["pin"]); $echoPHP->set_billing_ip_address(USER_IP); $echoPHP->set_billing_first_name($this->account["first_name"]); $echoPHP->set_billing_last_name($this->account["last_name"]); $echoPHP->set_billing_address1($this->account["address1"] . ' ' . $this->account["address2"]); $echoPHP->set_billing_city($this->account["city"]); $echoPHP->set_billing_state($this->account["state"]); $echoPHP->set_billing_zip($this->account["zip"]); $echoPHP->set_billing_country($country); $echoPHP->set_billing_email($acct_fields["email"]); $echoPHP->set_grand_total($amount); $echoPHP->set_ccexp_month($this->billing["exp_month"]); $echoPHP->set_ccexp_year($this->billing["exp_year"]); $echoPHP->set_cnp_security($this->billing["ccv"]); $echoPHP->set_cc_number($this->billing["cc_no"]); $echoPHP->set_counter($echoPHP->getRandomCounter()); # Set the return codes: if (!$echoPHP->Submit()) { if ($echoPHP->decline_code == "1013") { $ret['status'] = 0; $ret['msg'] = $echoPHP->avs_result . 'Echo account ' . $echoPHP->merchant_echo_id . ' could not be found, failed!'; } else { $ret['status'] = 0; $ret['msg'] = $echoPHP->echotype1; } } else { $ret['status'] = 1; $ret['transaction_id'] = $echoPHP->reference; $ret['authorization'] = $echoPHP->authorization; # AVS Details: if ($echoPHP->avs_result == 'A') { $ret['avs'] = 'avs_address_only'; } elseif ($echoPHP->avs_result == 'E') { $ret['avs'] = 'avs_error'; } elseif ($echoPHP->avs_result == 'N') { $ret['avs'] = 'avs_no_match'; } elseif ($echoPHP->avs_result == 'P') { $ret['avs'] = 'avs_na'; } elseif ($echoPHP->avs_result == 'R') { $ret['avs'] = 'avs_retry'; } elseif ($echoPHP->avs_result == 'S' || $echoPHP->avs_result == 'G') { $ret['avs'] = 'avs_not_supported'; } elseif ($echoPHP->avs_result == 'U') { $ret['avs'] = 'avs_address_unavail'; } elseif ($echoPHP->avs_result == 'W') { $ret['avs'] = 'avs_fullzip_only'; } elseif ($echoPHP->avs_result == 'X') { $ret['avs'] = 'avs_exact'; } elseif ($echoPHP->avs_result == 'D' || $echoPHP->avs_result == 'M') { $ret['avs'] = 'avs_address_zip'; } elseif ($echoPHP->avs_result == 'Z') { $ret['avs'] = 'avs_partzip_only'; } else { $ret['avs'] = 'avs_na'; } } if ($ret['status'] == 1) { return $ret; } else { global $VAR; @($VAR['msg'] = $ret["msg"]); return false; } }
function openecho_capture($params) { $echoPHP = new EchoPHP(); $echoPHP->set_EchoServer("https://wwws.echo-inc.com/scripts/INR200.EXE"); $echoPHP->set_transaction_type("EV"); $echoPHP->set_order_type("S"); $echoPHP->set_merchant_echo_id($params['merchantechoid']); $echoPHP->set_merchant_pin($params['merchantpin']); $echoPHP->set_billing_ip_address($_SERVER['REMOTE_ADDR']); $echoPHP->set_billing_first_name($params['clientdetails']['firstname']); $echoPHP->set_billing_last_name($params['clientdetails']['lastname']); $echoPHP->set_billing_address1($params['clientdetails']['address1']); $echoPHP->set_billing_city($params['clientdetails']['city']); $echoPHP->set_billing_state($params['clientdetails']['state']); $echoPHP->set_billing_zip($params['clientdetails']['postcode']); $echoPHP->set_billing_country($params['clientdetails']['country']); $echoPHP->set_billing_phone($params['clientdetails']['phonenumber']); $echoPHP->set_billing_email($params['clientdetails']['email']); $echoPHP->set_debug("F"); $echoPHP->set_cc_number($params['cardnum']); $echoPHP->set_grand_total($params['amount']); $echoPHP->set_ccexp_month(substr($params['cardexp'], 0, 2)); $echoPHP->set_ccexp_year("20" . substr($params['cardexp'], 2, 2)); $echoPHP->set_cnp_security($params['cccvv']); $echoPHP->set_counter("1"); $desc = "Action => Capture\n"; $desc .= "Client => " . $params['clientdetails']['firstname'] . " " . $params['clientdetails']['lastname'] . "\n"; $desc .= "Authorization Code => " . $echoPHP->authorization . "\n"; $desc .= "Order Number => " . $echoPHP->order_number . "\n"; $desc .= "Reference => " . $echoPHP->reference . "\n"; $desc .= "Status => " . $echoPHP->status . "\n"; $desc .= "AVS Result => " . $echoPHP->avs_result . "\n"; $desc .= "Security Result => " . $echoPHP->security_result . "\n"; $desc .= "MAC => " . $echoPHP->mac . "\n"; $desc .= "Decline Code => " . $echoPHP->decline_code . "\n"; $desc .= "Transaction Date => " . $echoPHP->tran_date . "\n"; $desc .= "Merchant Name => " . $echoPHP->merchant_name . "\n"; $desc .= "Version => " . $echoPHP->version . "\n"; $desc .= "Echo Type 1 => " . $echoPHP->echotype1 . "\n"; $desc .= "Echo Type 2 => " . $echoPHP->echotype2 . "\n"; $desc .= "Echo Type 3 => " . $echoPHP->echotype3 . "\n"; $desc .= "Echo Response => " . $echoPHP->EchoResponse . "\n"; if (!$echoPHP->Submit()) { return array("status" => "declined", "rawdata" => $desc); } return array("status" => "success", "transid" => $echoPHP->reference, "rawdata" => $desc); }
function cc_bill($cc_info, $member, $amount, $currency, $product_description, $charge_type, $invoice, $payment) { global $config; $log = array(); //////////////////////// cc_bill ///////////////////////// $echoPHP = new EchoPHP(); $echoPHP->set_EchoServer("https://wwws.echo-inc.com/scripts/INR200.EXE"); $echoPHP->set_order_type("S"); $echoPHP->set_merchant_echo_id($this->config['merchant_id']); // use your own id here $echoPHP->set_merchant_pin($this->config['pin']); // use your own pin here $echoPHP->set_billing_phone($cc_info['cc_phone']); $echoPHP->set_billing_first_name($cc_info['cc_name_f']); $echoPHP->set_billing_last_name($cc_info['cc_name_l']); $echoPHP->set_billing_address1($cc_info['cc_street']); $echoPHP->set_billing_city($cc_info['cc_city']); $echoPHP->set_billing_state($cc_info['cc_state']); $echoPHP->set_billing_zip($cc_info['cc_zip']); $echoPHP->set_billing_country($cc_info['cc_country']); $echoPHP->set_billing_phone($cc_info['cc_phone']); $echoPHP->set_billing_email($member['email']); $echoPHP->set_cc_number($cc_info['cc_number']); $echoPHP->set_ccexp_month(substr($cc_info['cc-expire'], 0, 2)); $echoPHP->set_ccexp_year(substr($cc_info['cc-expire'], 2, 2)); $echoPHP->set_counter($echoPHP->getRandomCounter()); switch ($charge_type) { case CC_CHARGE_TYPE_TEST: $echoPHP->set_transaction_type("AD"); $echoPHP->set_billing_ip_address($_SERVER['REMOTE_ADDR']); $echoPHP->set_cnp_security($cc_info['cc_code']); break; default: $echoPHP->set_transaction_type("EV"); $echoPHP->set_grand_total($amount); if ($charge_type != CC_CHARGE_TYPE_RECURRING) { $echoPHP->set_billing_ip_address($_SERVER['REMOTE_ADDR']); $echoPHP->set_cnp_security($cc_info['cc_code']); } else { $echoPHP->set_cnp_recurring('Y'); } } $x = $echoPHP->getURLData(); $x = str_replace($cc_info['cc_number'], $cc_info['cc'], $x); $x = str_replace('cnp_security=' . $cc_info['cc_code'], 'cnp_security=' . preg_replace('/./', '*', $cc_info['cc_code']) . '&', $x); $x = preg_replace('/(merchant_pin\\=)(\\d+)/', '\\1********', $x); parse_str($x, $x); $log[] = $x; $ECHO_ERROR = !$echoPHP->Submit(); // find out reply and parse it preg_match('/<ECHOTYPE3>(.+?)<\\/ECHOTYPE3>/', $echoPHP->EchoResponse, $regs); preg_match_all('/<(.+?)>(.+?)<\\/(.+?)>/', $regs[1], $matches); $res = array(); foreach ($matches[1] as $k => $fname) { $res[$fname] = $matches[2][$k]; } $log[] = $res; if ($ECHO_ERROR) { if ($echoPHP->decline_code == "1013") { return array(CC_RESULT_INTERNAL_ERROR, "Configuration error: Your ECHO-ID or PIN is missing from this form, or is not setup correctly. Check if you can login with your ECHO-ID and PIN to <a href=\"https://wwws.echo-inc.com/Review\">Transaction Review</a>.", "", $log); } else { return array(CC_RESULT_DECLINE_PERM, "Verification of your account FAILED", "", $log); } } else { return array(CC_RESULT_SUCCESS, "", $echoPHP->get_order_number(), $log); } }