| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366 | 
							- <?php
 
- /**
 
-  *
 
-  * PHP Pro Bid $Id$ qWJyUgLGiW9PBPnpNR5oPvdvIclZlfujxSRIR/AFhGU=
 
-  *
 
-  * @link        http://www.phpprobid.com
 
-  * @copyright   Copyright (c) 2015 Online Ventures Software & CodeCube SRL
 
-  * @license     http://www.phpprobid.com/license Commercial License
 
-  *
 
-  * @version     7.4
 
-  */
 
- /**
 
-  * authorize.net payment gateway model class
 
-  */
 
- namespace Ppb\Model\PaymentGateway;
 
- use Cube\Controller\Request\AbstractRequest;
 
- class AuthorizeNet extends AbstractPaymentGateway
 
- {
 
-     /**
 
-      * payment gateway name
 
-      */
 
-     const NAME = 'AuthorizeNet';
 
-     /**
 
-      * required settings
 
-      */
 
-     const MERCHANT_ID = 'x_login';
 
-     const TRANSACTION_KEY = 'authnet_transaction_key';
 
-     const MD5_HASH = 'x_MD5_Hash';
 
-     const SANDBOX_MODE = 'sandbox_mode';
 
-     /**
 
-      * form post url
 
-      */
 
-     const POST_URL = 'https://secure.authorize.net/gateway/transact.dll';
 
-     /**
 
-      * form post url (sandbox)
 
-      */
 
-     const SANDBOX_POST_URL = 'https://test.authorize.net/gateway/transact.dll';
 
-     /**
 
-      * 2checkout description
 
-      */
 
-     protected $_description = 'Click to pay through Authorize.net.';
 
-     protected $_ipnCodes = array(
 
-         1 => 'Approved',
 
-         2 => 'Declined',
 
-         3 => 'Error',
 
-         4 => 'Held for Review',
 
-     );
 
-     public function __construct($userId = null)
 
-     {
 
-         parent::__construct(self::NAME, $userId);
 
-     }
 
-     /**
 
-      *
 
-      * check if the gateway is enabled
 
-      *
 
-      * @return bool
 
-      */
 
-     public function enabled()
 
-     {
 
-         if (!empty($this->_data[self::MERCHANT_ID]) && !empty($this->_data[self::TRANSACTION_KEY])) {
 
-             return true;
 
-         }
 
-         return false;
 
-     }
 
-     /**
 
-      *
 
-      * get setup form elements
 
-      *
 
-      * @return array
 
-      */
 
-     public function getElements()
 
-     {
 
-         $translate = $this->getTranslate();
 
-         return array(
 
-             array(
 
-                 'form_id'     => 'AuthorizeNet',
 
-                 'id'          => self::MERCHANT_ID,
 
-                 'element'     => 'text',
 
-                 'label'       => $this->_('Authorize.net Merchant ID'),
 
-                 'description' => $this->_('Enter your merchant ID'),
 
-                 'attributes'  => array(
 
-                     'class' => 'form-control input-medium',
 
-                 ),
 
-             ),
 
-             array(
 
-                 'form_id'     => 'AuthorizeNet',
 
-                 'id'          => self::TRANSACTION_KEY,
 
-                 'element'     => 'text',
 
-                 'label'       => $this->_('Authorize.net Transaction Key'),
 
-                 'description' => $this->_('Enter your assigned transaction key'),
 
-                 'attributes'  => array(
 
-                     'class' => 'form-control input-medium',
 
-                 ),
 
-             ),
 
-             array(
 
-                 'form_id'     => 'AuthorizeNet',
 
-                 'id'          => self::MD5_HASH,
 
-                 'element'     => 'text',
 
-                 'label'       => $this->_('Authorize.net MD5 Hash'),
 
-                 'description' => $this->_('(recommended) enter your set md5 hash value if you wish for the ipn requests to be encrypted <br>'
 
-                         . 'Authorize.net Relay Response URL: <br>') . $this->getIpnUrl(),
 
-                 'attributes'  => array(
 
-                     'class' => 'form-control input-medium',
 
-                 ),
 
-             ),
 
-             array(
 
-                 'form_id'      => 'AuthorizeNet',
 
-                 'id'           => self::SANDBOX_MODE,
 
-                 'element'      => 'checkbox',
 
-                 'label'        => $this->_('Sandbox Mode'),
 
-                 'description'  => $this->_('Check the above checkbox to activate the sandbox mode.'),
 
-                 'multiOptions' => array(
 
-                     1 => null,
 
-                 ),
 
-             ),
 
-         );
 
-     }
 
-     public function formElements()
 
-     {
 
-         $timestamp = time();
 
-         return array(
 
-             array(
 
-                 'id'      => 'x_version',
 
-                 'value'   => '3.1',
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => self::MERCHANT_ID,
 
-                 'value'   => $this->_data[self::MERCHANT_ID],
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_type',
 
-                 'value'   => 'AUTH_CAPTURE',
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_method',
 
-                 'value'   => 'CC',
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_amount',
 
-                 'value'   => $this->getAmount(),
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_show_form',
 
-                 'value'   => 'PAYMENT_FORM',
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_relay_response',
 
-                 'value'   => 'TRUE',
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_test_request',
 
-                 'value'   => ($this->_isSandboxMode()) ? 'TRUE' : 'false',
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_description',
 
-                 'value'   => $this->_shortenString($this->getName(), 255),
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_invoice_num',
 
-                 'value'   => $this->getTransactionId(),
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_currency_code',
 
-                 'value'   => $this->getCurrency(),
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_fp_hash',
 
-                 'value'   => $this->_createHash($timestamp),
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_fp_sequence',
 
-                 'value'   => $this->getTransactionId(),
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_fp_timestamp',
 
-                 'value'   => $timestamp,
 
-                 'element' => 'hidden',
 
-             ),
 
-             array(
 
-                 'id'      => 'x_cancel_url',
 
-                 'value'   => $this->getFailureUrl(),
 
-                 'element' => 'hidden',
 
-             ),
 
-         );
 
-     }
 
-     /**
 
-      *
 
-      * get the form post url (live or sandbox)
 
-      *
 
-      * @return string
 
-      */
 
-     public function getPostUrl()
 
-     {
 
-         return ($this->_isSandboxMode()) ?
 
-             self::SANDBOX_POST_URL : self::POST_URL;
 
-     }
 
-     /**
 
-      *
 
-      * process ipn
 
-      *
 
-      * @param \Cube\Controller\Request\AbstractRequest $request
 
-      *
 
-      * @return bool
 
-      */
 
-     public function processIpn(AbstractRequest $request)
 
-     {
 
-         $response = false;
 
-         if ($request->isPost()) {
 
-             $paymentStatus = $request->getParam('x_response_code');
 
-             $this->setTransactionId($request->getParam('x_invoice_num'))
 
-                 ->setAmount($request->getParam('x_amount'))
 
-                 ->setCurrency($request->getParam('x_currency_code'))
 
-                 ->setGatewayPaymentStatus($this->_ipnCodes[$paymentStatus])
 
-                 ->setGatewayTransactionCode($request->getParam('x_trans_id'));
 
-             if (!$this->_validateMd5Sig($request)) {
 
-                 $this->setGatewayPaymentStatus('Invalid MD5 Hash');
 
-             }
 
-             else if ($paymentStatus == 1) {
 
-                 $response = true;
 
-             }
 
-         }
 
-         return $response;
 
-     }
 
-     /**
 
-      *
 
-      * method that checks if the amount and currency submitted through an ipn is the
 
-      * coincides with the row in the transactions table
 
-      *
 
-      * @param float  $amount
 
-      * @param string $currency
 
-      *
 
-      * @return bool
 
-      */
 
-     public function checkIpnAmount($amount, $currency)
 
-     {
 
-         if ($this->_amount == $amount && in_array($currency, array('USD', 'CAD', 'GBP'))) {
 
-             return true;
 
-         }
 
-         return false;
 
-     }
 
-     /**
 
-      *
 
-      * generates the required x_fp_hash variable, based on merchant id, transaction id (x_fp_sequence), timestamp and payment amount
 
-      * and hashed using the merchant's transaction key
 
-      *
 
-      * @param int $timestamp
 
-      *
 
-      * @return string
 
-      */
 
-     private function _createHash($timestamp)
 
-     {
 
-         return $this->_hmac($this->_data[self::TRANSACTION_KEY],
 
-             $this->_data[self::MERCHANT_ID] . '^' . $this->getTransactionId() . '^' . $timestamp . '^' . $this->getAmount() . '^' . $this->getCurrency());
 
-     }
 
-     /**
 
-      *
 
-      * RFC 2104 HMAC implementation for php.
 
-      * Creates an md5 HMAC.
 
-      * Eliminates the need to install mhash to compute a HMAC
 
-      * Hacked by Lance Rushing
 
-      *
 
-      * @param string $key
 
-      * @param string $data
 
-      *
 
-      * @return string
 
-      */
 
-     private function _hmac($key, $data)
 
-     {
 
-         $b = 64; // byte length for md5
 
-         if (strlen($key) > $b) {
 
-             $key = pack("H*", md5($key));
 
-         }
 
-         $key = str_pad($key, $b, chr(0x00));
 
-         $iPad = str_pad('', $b, chr(0x36));
 
-         $oPad = str_pad('', $b, chr(0x5c));
 
-         $kIPad = $key ^ $iPad;
 
-         $kOPad = $key ^ $oPad;
 
-         return md5($kOPad . pack("H*", md5($kIPad . $data)));
 
-     }
 
-     /**
 
-      *
 
-      * validate ipn md5 hash
 
-      *
 
-      * @param AbstractRequest $request
 
-      *
 
-      * @return bool
 
-      */
 
-     private function _validateMd5Sig(AbstractRequest $request)
 
-     {
 
-         if (empty($this->_data[self::MD5_HASH])) {
 
-             return true;
 
-         }
 
-         $string = $this->_data[self::MD5_HASH]
 
-             . $this->_data[self::MERCHANT_ID]
 
-             . $request->getParam('x_trans_id')
 
-             . $request->getParam('x_amount');
 
-         if (strcasecmp(md5($string), $request->getParam(self::MD5_HASH)) === 0) {
 
-             return true;
 
-         }
 
-         return false;
 
-     }
 
-     /**
 
-      *
 
-      * check if sandbox mode is enabled
 
-      *
 
-      * @return bool
 
-      */
 
-     protected function _isSandboxMode()
 
-     {
 
-         $sandbox = (isset($this->_data[self::SANDBOX_MODE])) ? $this->_data[self::SANDBOX_MODE] : false;
 
-         return (bool)$sandbox;
 
-     }
 
- }
 
 
  |