<?php /** * AgileBill - Open Billing Software * * This body of work is free software; you can redistribute it and/or * modify it under the terms of the Open AgileBill License * License as published at http://www.agileco.com/agilebill/license1-4.txt * * For questions, help, comments, discussion, etc., please join the * Agileco community forums at http://forum.agileco.com/ * * @link http://www.agileco.com/ * @copyright 2004-2008 Agileco, LLC. * @license http://www.agileco.com/agilebill/license1-4.txt * @author Tony Landis <tony@agileco.com> * @package AgileBill * @version 1.4.93 */ include_once(PATH_MODULES.'checkout/base_checkout_plugin.class.php'); class plg_chout_SUREPAY extends base_checkout_plugin { # Get the config values for this checkout plugin: function plg_chout_SUREPAY ($checkout_id=false) { $this->name = 'SUREPAY'; $this->type = 'gateway'; // redirect, gateway, or other $this->recurr_only = false; $this->checkout_id = $checkout_id; $this->support_cur = Array ('USD'); $this->host_test = 'xml.test.surepay.com'; $this->host_live = 'xml.surepay.com'; $this->url = '/'; $this->getDetails($checkout_id); } # Validate the user submitted billing details at checkout: function validate($VAR) { return true; } # Perform the checkout transaction (new purchase): 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('name', $this->account["country_id"]); # Get the data submitted from the customer: $billing = @$VAR['checkout_plugin_data']; # Test mode: if ( $this->cfg['mode'] ) $this->host = $this->host_live; else $this->host = $this->host_test; # Assemble the XML request $xml_request = '<!DOCTYPE pp.request PUBLIC "-//IMALL//DTD PUREPAYMENTS 1.0//EN" "http://www.purepayments.com/dtd/purepayments.dtd">'; $xml_request.=' <pp.request merchant="' . $this->cfg['account'] . '" password="' . $this->cfg['password'] . '"> <pp.auth ordernumber="' . $invoice .'" ecommerce="true" ecommercecode="07" ponumber="' . $this->account["first_name"].' '.$this->account["last_name"] .'" ipaddress="' . USER_IP .'" shippingcost="0.00USD" taxamount="0.00USD" referringurl="NA" browsertype="NA"> <pp.lineitem quantity="1" sku="NA" description="Invoice ' . $invoice .'" unitprice="' . $amount .'USD" taxrate="0.00" /> <pp.creditcard number="' . $this->billing["cc_no"] .'" expiration="' . $this->billing["exp_month"] . '/'.$this->billing["exp_year"] .'" cvv2="'.$this->billing["ccv"].'" cvv2status="1"> <pp.address type="billing" fullname="' . $this->account["first_name"].' '.$this->account["last_name"] .'" address1="' . $this->account["address1"] .'" address2="'.$this->account["address2"].'" city="' . $this->account["city"] .'" state="' . $this->account["state"] .'" zip="' . $this->account["zip"] .'" country="' . $country .'" phone="" email="' . $acct_fields["email"] .'" /> </pp.creditcard> <pp.ordertext type="instructions">Payment for order ' . $invoice .'</pp.ordertext> <pp.address type="shipping" fullname="' . $this->account["first_name"].' '.$this->account["last_name"] .'" address1="' . $this->account["address1"] .'" address2="'.$this->account["address2"].'" city="' . $this->account["city"] .'" state="' . $this->account["state"] .'" zip="' . $this->account["zip"] .'" country="' . $country .'" phone="" email="' . $acct_fields["email"] .'" /> </pp.auth> </pp.request>'; # Set the post vars: $vars = Array ( Array ('xml', $xml_request) ); # Create the SSL connection & get response from the gateway: include_once (PATH_CORE . 'ssl.inc.php'); $n = new CORE_ssl; $response = $n->connect($this->host, $this->url, $vars, true, 1); # Get return response if(!$response) return false; else $respond = explode('&', $response); for ($i=0; $i<count($respond); $i++) { @$arr1 = explode('=', $respond[$i]); @$response1[urldecode($arr1[0])] = urldecode($arr1[1]); } # Transaction Status: if (trim($response1['?valid']) == 'true') $ret['status'] = 1; else $ret['status'] = 0; # Transaction ID: $ret['transaction_id'] = $response1["trans_id"]; $ret['authorization_id'] = $response1["auth_code"]; # Message: $ret['msg'] = $response; # AVS Details: $ret['avs'] = 'avs_na'; if($ret['status'] == 1) { return $ret; } else { global $VAR; @$VAR['msg']=$ret["msg"]; return false; } } # Stores new billing details, & return account_billing_id (gateway only) function store_billing($VAR, $account=SESS_ACCOUNT) { return $this->saveCreditCardDetails($VAR); } # Perform a transaction for an (new invoice): function bill_invoice($VAR) { return true; } # Issue a refund for a paid invoice (captured charges w/gateway) function refund($VAR) { return true; } # Void a authorized charge (gateways only) function void($VAR) { return true; } } ?>