* @package AgileBill * @version 1.4.93 */ include_once(PATH_MODULES.'checkout/base_checkout_plugin.class.php'); class plg_chout_PAYSWISS_RECURRING extends base_checkout_plugin { # Get the config values for this checkout plugin: function plg_chout_PAYSWISS_RECURRING($checkout_id=false) { $this->name = 'PAYSWISS_RECURRING'; $this->type = 'redirect'; // redirect, gateway, or other $this->recurr_only = true; $this->return_url = SSL_URL . 'plugins/checkout/'. $this->name .'.php'; $this->success_url = URL . '?_page=invoice:thankyou&_next_page=invoice:user_view&id='; $this->decline_url = URL . '?_page=invoice:user_view&id='; $this->support_cur = Array ('USD'); $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) { if(!$this->validate_currency($currency_iso)) return false; # PaySwiss cannot handle pro-rated subscriptions: if($recurr_bill_arr[0]["recurr_type"] != "0") { global $C_translate; $msg = $C_translate->translate('prorated_not_supported','checkout',''); echo ''; return false; } # Get the regular period for this subscription: $sched = $recurr_bill_arr[0]["recurr_schedule"]; if($sched == 0) { $period = '7'; } elseif ($sched == 1) { $period = '31'; } elseif ($sched == 2) { $period = '91'; } elseif ($sched == 3) { $period = '182'; } elseif ($sched == 4) { $period = '365'; } elseif ($sched == 5) { $period = '730'; } $setup = "0.00"; if($amount > $total_recurring) $setup = number_format($amount - $total_recurring,2); $url = "https://www.payswiss.com/process.php"; $vals = Array ( Array ('username', $this->cfg['email']), Array ('action', 'subscription'), Array ('product', SITE_NAME. ' - Invoice # '.$invoice), Array ('price', $total_recurring), Array ('action', 'payment'), Array ('quantity', '1'), Array ('ucancel', $this->decline_url.$invoice), Array ('unotify', $this->return_url), Array ('ureturn', $this->success_url.$invoice), Array ('period', $period), Array ('setup', $setup) ); $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; } } ?>