Initial Commit of AgileBill Open Source
This commit is contained in:
190
plugins/checkout/2CHECKOUT_V2.php
Normal file
190
plugins/checkout/2CHECKOUT_V2.php
Normal file
@@ -0,0 +1,190 @@
|
||||
<?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
|
||||
*/
|
||||
|
||||
/*
|
||||
Be sure to set the Return Url to point to this script under 'Cart Details' and
|
||||
Direct Return to 'Yes' in the 2checkout admin area
|
||||
*/
|
||||
|
||||
if(defined('PATH_MODULES')) include_once(PATH_MODULES.'checkout/base_checkout_plugin.class.php'); else include_once('../../modules/checkout/base_checkout_plugin.class.php');
|
||||
|
||||
class plg_chout_2CHECKOUT_V2 extends base_checkout_plugin
|
||||
{
|
||||
# Get the config values for this checkout plugin:
|
||||
function plg_chout_2CHECKOUT_V2($checkout_id=false) {
|
||||
|
||||
$this->name = '2CHECKOUT_V2';
|
||||
$this->type = 'redirect';
|
||||
$this->recurr_only = false;
|
||||
$this->support_cur = Array ('USD','GBP', 'EUR');
|
||||
$this->success_url = URL . '?_page=invoice:user_view&id=';
|
||||
$this->decline_url = URL . '?_page=invoice:user_view&id=';
|
||||
$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 the currency:
|
||||
if(!$this->validate_currency($currency_iso)) return false;
|
||||
|
||||
if($this->cfg['mode'] == "Y") {
|
||||
$demo1 = 'demo';
|
||||
$demo2 = 'Y';
|
||||
} else {
|
||||
$demo1 = '';
|
||||
$demo2 = '';
|
||||
}
|
||||
|
||||
$url = "https://www2.2checkout.com/2co/buyer/purchase";
|
||||
$vals = Array (
|
||||
Array ('sid', $this->cfg['id']),
|
||||
Array ('total', $amount),
|
||||
Array ('cart_order_id', $invoice),
|
||||
Array ('card_holder_name', $acct_fields['first_name'] . ' ' . $acct_fields['last_name']),
|
||||
Array ('street_address', $acct_fields['address1']),
|
||||
Array ('city', $acct_fields['city']),
|
||||
Array ('state', $acct_fields['state']),
|
||||
Array ('zip', $acct_fields['zip']),
|
||||
Array ('email', $acct_fields['email']),
|
||||
Array ($demo1, $demo2)
|
||||
);
|
||||
|
||||
$this->post_vars($url, $vals);
|
||||
return true;
|
||||
}
|
||||
|
||||
# Stores new billing details, & return account_billing_id (gateway only)
|
||||
function store_billing($VAR) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
# 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;
|
||||
}
|
||||
|
||||
# Postback Validation
|
||||
function postback($VAR)
|
||||
{
|
||||
# needed for return
|
||||
$ret['invoice_id'] = $VAR['merchant_product_id'];
|
||||
$ret['transaction_id'] = $VAR['order_number'];
|
||||
$ret['amount'] = $VAR['total'];
|
||||
$ret['status'] = true;
|
||||
$ret['currency'] = DEFAULT_CURRENCY;
|
||||
|
||||
# needed for verification
|
||||
$order_number = $VAR['merchant_product_id']; // invoice_id
|
||||
$order_id = $VAR['order_number']; // transaction id
|
||||
$amount = $VAR['total']; // total
|
||||
|
||||
# get the processor details:
|
||||
$db = &DB();
|
||||
$q = "SELECT id,active,plugin_data FROM ".AGILE_DB_PREFIX."checkout WHERE
|
||||
site_id = ".$db->qstr(DEFAULT_SITE)." AND
|
||||
checkout_plugin = ".$db->qstr($this->name);
|
||||
$rs = $db->Execute($q);
|
||||
while(!$rs->EOF)
|
||||
{
|
||||
$ret['checkout_id'] = $rs->fields["id"];
|
||||
$do = true;
|
||||
$this->cfg = unserialize($rs->fields["plugin_data"]);
|
||||
|
||||
# Get the 2checkout settings
|
||||
$sid = $this->cfg['id']; // store id
|
||||
$secret_word = $this->cfg['secret']; // secret word
|
||||
|
||||
# Test for demo mode
|
||||
if (($VAR['demo'] == "Y") && ($this->cfg['mode'] != "Y")) {
|
||||
$do = $false;
|
||||
} elseif ($VAR['demo'] == "Y") {
|
||||
$oid = '1';
|
||||
} else {
|
||||
$oid = $order_id;
|
||||
}
|
||||
|
||||
# If the secret word is set, validate it against what is posted
|
||||
if(!empty($secret_word)) {
|
||||
$hash_remote = strtoupper($VAR['key']);
|
||||
$string = $secret_word.$sid.$oid.$amount;
|
||||
$hash_local = strtoupper(md5($string));
|
||||
if($hash_local != $hash_remote) {
|
||||
$do = false;
|
||||
}
|
||||
}
|
||||
|
||||
# Validate agains the posted 2checkout id:
|
||||
if($sid != $VAR['sid']) {
|
||||
$do = false;
|
||||
}
|
||||
|
||||
if($do) {
|
||||
include_once(PATH_MODULES.'checkout/checkout.inc.php');
|
||||
$checkout = new checkout;
|
||||
$checkout->postback($ret);
|
||||
echo '<SCRIPT LANGUAGE="JavaScript">
|
||||
window.location="?_page=invoice:thankyou&_next_page=invoice:user_view&id='.$ret['invoice_id'].'";
|
||||
</script>';
|
||||
return true;
|
||||
}
|
||||
$rs->MoveNext();
|
||||
}
|
||||
|
||||
echo '<SCRIPT LANGUAGE="JavaScript">
|
||||
window.location="'.$this->decline_url.$ret['invoice_id'].'";
|
||||
</script>';
|
||||
}
|
||||
}
|
||||
|
||||
# Postback Function
|
||||
if(empty($VAR) && empty($VAR['do']))
|
||||
{
|
||||
include_once('../../config.inc.php');
|
||||
require_once(PATH_ADODB . 'adodb.inc.php');
|
||||
require_once(PATH_CORE . 'database.inc.php');
|
||||
require_once(PATH_CORE . 'setup.inc.php');
|
||||
require_once(PATH_CORE . 'vars.inc.php');
|
||||
|
||||
$C_debug = new CORE_debugger;
|
||||
$C_vars = new CORE_vars;
|
||||
$VAR = $C_vars->f;
|
||||
$C_db = &DB();
|
||||
$C_setup = new CORE_setup;
|
||||
|
||||
$plg = new plg_chout_2CHECKOUT_V2;
|
||||
$plg->postback($VAR);
|
||||
}
|
||||
?>
|
Reference in New Issue
Block a user