ok
Direktori : /home2/selectio/www/geniusgroove.in/crm/application/controllers/onlineadmission/ |
Current File : /home2/selectio/www/geniusgroove.in/crm/application/controllers/onlineadmission/Onepay.php |
<?php if (!defined('BASEPATH')) exit('No direct script access allowed'); class Onepay extends OnlineAdmission_Controller { public $api_config = ""; public $amount = 0; function __construct() { parent::__construct(); $this->api_config = $this->paymentsetting_model->getActiveMethod(); $this->setting = $this->setting_model->getSetting(); $this->amount = $this->setting->online_admission_amount; $this->load->library('mailsmsconf'); $this->load->model('onlinestudent_model'); } public function index() { $reference = $this->session->userdata('reference'); $data['setting'] = $this->setting; $total = $this->amount; $data['amount'] = $total; $data['error']=array(); $this->load->view('onlineadmission/onepay/index', $data); } public function pay() { $this->session->set_userdata('payment_amount',$this->amount); $reference = $this->session->userdata('reference'); $currentdate = date('Y-m-d'); $adddata = array('id' => $reference, 'form_status' => 1, 'submit_date' => $currentdate); $this->onlinestudent_model->edit($adddata); $buyer_data = $this->onlinestudent_model->getAdmissionData($reference); $amount = convertBaseAmountCurrencyFormat($this->amount); $appendAmp = 0; $SECURE_SECRET =$this->api_config->api_signature; $payment_data=array( 'AVS_City' => '', 'AVS_Country' =>'', 'AVS_PostCode' => '', 'AVS_StateProv' => '', 'AVS_Street01' => '', 'AgainLink' => urlencode($_SERVER['HTTP_REFERER']), 'Title' => '', 'display' => '', 'vpc_AccessCode' => $this->api_config->salt, 'vpc_Amount' => $amount*100, 'vpc_Command' => 'pay', 'vpc_Customer_Email' => '', 'vpc_Customer_Id' => '', 'vpc_Customer_Phone' => '', 'vpc_Locale' => 'en', 'vpc_MerchTxnRef' => date('YmdHis') . rand(), 'vpc_Merchant' => $this->api_config->api_publishable_key, 'vpc_OrderInfo' => 'JSECURETEST01', 'vpc_ReturnURL' => base_url() . 'onlineadmission/onepay/complete', 'vpc_SHIP_City' => '', 'vpc_SHIP_Country' => '', 'vpc_SHIP_Provice' => '', 'vpc_SHIP_Street01' => '', 'vpc_TicketNo' => $_SERVER ['REMOTE_ADDR'], 'vpc_Version' => '2'); $vpcURL="https://mtf.onepay.vn/paygate/vpcpay.op?"; foreach($payment_data as $key => $value) { if (strlen($value) > 0) { if ($appendAmp == 0) { $vpcURL .= urlencode($key) . '=' . urlencode($value); $appendAmp = 1; } else { $vpcURL .= '&' . urlencode($key) . "=" . urlencode($value); } if ((strlen($value) > 0) && ((substr($key, 0,4)=="vpc_") || (substr($key,0,5) =="user_"))) { $md5HashData .= $key . "=" . $value . "&"; } } } $md5HashData = rtrim($md5HashData, "&"); if (strlen($SECURE_SECRET) > 0) { $vpcURL .= "&vpc_SecureHash=" . strtoupper(hash_hmac('SHA256', $md5HashData, pack('H*',$SECURE_SECRET))); } header("Location: ".$vpcURL); } /** * This is a callback function for movies payment completion */ public function complete() { $reference = $this->session->userdata('reference'); $online_data = $this->onlinestudent_model->getAdmissionData($reference); $apply_date = date("Y-m-d H:i:s"); $date = date($this->customlib->getSchoolDateFormat(), $this->customlib->dateyyyymmddTodateformat(date("Y-m-d", strtotime($apply_date)))); $SECURE_SECRET = $this->api_config->api_signature; $vpc_Txn_Secure_Hash = $_GET["vpc_SecureHash"]; $vpc_MerchTxnRef = $_GET["vpc_MerchTxnRef"]; $vpc_AcqResponseCode = $_GET["vpc_AcqResponseCode"]; unset($_GET["vpc_SecureHash"]); $errorExists = false; if (strlen($SECURE_SECRET) > 0 && $_GET["vpc_TxnResponseCode"] != "7" && $_GET["vpc_TxnResponseCode"] != "No Value Returned") { ksort($_GET); $md5HashData = ""; foreach ($_GET as $key => $value) { if ($key != "vpc_SecureHash" && (strlen($value) > 0) && ((substr($key, 0,4)=="vpc_") || (substr($key,0,5) =="user_"))) { $md5HashData .= $key . "=" . $value . "&"; } } $md5HashData = rtrim($md5HashData, "&"); if (strtoupper ( $vpc_Txn_Secure_Hash ) == strtoupper(hash_hmac('SHA256', $md5HashData, pack('H*',$SECURE_SECRET)))) { $hashValidated = "CORRECT"; } else { $hashValidated = "INVALID HASH"; } } else { $hashValidated = "INVALID HASH"; } $txnResponseCode = $this->null2unknown($_GET["vpc_TxnResponseCode"]); $verType = array_key_exists("vpc_VerType", $_GET) ? $_GET["vpc_VerType"] : "No Value Returned"; $verStatus = array_key_exists("vpc_VerStatus", $_GET) ? $_GET["vpc_VerStatus"] : "No Value Returned"; $token = array_key_exists("vpc_VerToken", $_GET) ? $_GET["vpc_VerToken"] : "No Value Returned"; $verSecurLevel = array_key_exists("vpc_VerSecurityLevel", $_GET) ? $_GET["vpc_VerSecurityLevel"] : "No Value Returned"; $enrolled = array_key_exists("vpc_3DSenrolled", $_GET) ? $_GET["vpc_3DSenrolled"] : "No Value Returned"; $xid = array_key_exists("vpc_3DSXID", $_GET) ? $_GET["vpc_3DSXID"] : "No Value Returned"; $acqECI = array_key_exists("vpc_3DSECI", $_GET) ? $_GET["vpc_3DSECI"] : "No Value Returned"; $authStatus = array_key_exists("vpc_3DSstatus", $_GET) ? $_GET["vpc_3DSstatus"] : "No Value Returned"; $errorTxt = ""; if ($txnResponseCode == "7" || $txnResponseCode == "No Value Returned" || $errorExists) { $errorTxt = "Error "; } $transStatus = ""; if($hashValidated=="CORRECT" && $txnResponseCode=="0"){ $transStatus = "success"; $payment_id = $_GET["vpc_MerchTxnRef"]; $amount = $this->session->userdata('payment_amount'); $reference = $this->session->userdata('reference'); $currentdate = date('Y-m-d'); $adddata = array('id' => $reference, 'form_status' => 1, 'submit_date' => $currentdate); $this->onlinestudent_model->edit($adddata); $transactionid = $payment_id; $gateway_response['online_admission_id'] = $reference; $gateway_response['paid_amount'] = $amount; $gateway_response['transaction_id'] = $transactionid; $gateway_response['payment_mode'] = 'onepay'; $gateway_response['payment_type'] = 'online'; $gateway_response['note'] = $this->lang->line('online_fees_deposit_through_onepay_txn_id') . $transactionid; $gateway_response['date'] = date("Y-m-d H:i:s"); $return_detail = $this->onlinestudent_model->paymentSuccess($gateway_response); $sender_details = array('firstname' => $online_data->firstname, 'lastname' => $online_data->lastname, 'email' => $online_data->email,'date'=>$date,'reference_no'=>$online_data->reference_no,'mobileno'=>$online_data->mobileno,'paid_amount'=>$amount,'guardian_email'=>$online_data->guardian_email,'guardian_phone'=>$online_data->guardian_phone); $this->mailsmsconf->mailsms('online_admission_fees_submission', $sender_details); redirect(base_url("onlineadmission/checkout/successinvoice/".$online_data->reference_no)); }elseif ($hashValidated=="INVALID HASH" && $txnResponseCode=="0"){ $transStatus = "pending"; }else { $transStatus = "fail"; redirect(base_url("onlineadmission/checkout/paymentfailed/".$online_data->reference_no)); } } // If input is null, returns string "No Value Returned", else returns input public function null2unknown($data) { if ($data == "") { return "No Value Returned"; } else { return $data; } } }