5 * Licensed to CiviCRM under the Academic Free License version 3.0.
7 * Written and contributed by Phase2 Technology, LLC (http://www.phase2technology.com)
14 * @author Michael Morris and Gene Chi @ Phase2 Technology <mmorris@phase2technology.com>
18 require_once 'PayJunction/pjClasses.php';
20 class CRM_Core_Payment_PayJunction
extends CRM_Core_Payment
{
21 # (not used, implicit in the API, might need to convert?)
22 const CHARSET
= 'UFT-8';
25 * We only need one instance of this object. So we use the singleton
26 * pattern and cache the instance in this variable
30 static private $_singleton = NULL;
36 * The mode of operation: live or test.
38 * @param $paymentProcessor
40 * @return \CRM_Core_Payment_PayJunction
42 public function __construct($mode, &$paymentProcessor) {
44 $this->_paymentProcessor
= $paymentProcessor;
45 $this->_processorName
= ts('PayJunction');
49 * This function sends request and receives response from
50 * PayJunction payment process
52 * @param array $params
53 * Assoc array of input parameters for this transaction.
56 * the result in an nice formatted array (or an error object)
58 public function doDirectPayment(&$params) {
59 $logon = $this->_paymentProcessor
['user_name'];
60 $password = $this->_paymentProcessor
['password'];
61 $url_site = $this->_paymentProcessor
['url_site'];
63 // create pjpgCustInfo object
64 $pjpgCustInfo = new pjpgCustInfo();
66 $pjpgCustInfo->setEmail($params['email']);
70 "password" => $password,
71 "url_site" => $url_site,
72 "first_name" => $params['first_name'],
73 "last_name" => $params['last_name'],
74 "address" => $params['street_address'],
75 "city" => $params['city'],
76 "province" => $params['state_province'],
77 "postal_code" => $params['postal_code'],
78 "country" => $params['country'],
80 $pjpgCustInfo->setBilling($billing);
82 // create pjpgTransaction object
83 $my_orderid = $params['invoiceID'];
85 $expiry_string = sprintf('%04d%02d', $params['year'], $params['month']);
89 'order_id' => $my_orderid,
90 'amount' => sprintf('%01.2f', $params['amount']),
91 'pan' => $params['credit_card_number'],
92 'expdate' => $expiry_string,
94 'cavv' => $params['cvv2'],
95 'cust_id' => $params['contact_id'],
98 // Allow further manipulation of params via custom hooks
99 CRM_Utils_Hook
::alterPaymentProcessorParams($this, $params, $txnArray);
101 $pjpgTxn = new pjpgTransaction($txnArray);
103 // set customer info (level 3 data) for the transaction
104 $pjpgTxn->setCustInfo($pjpgCustInfo);
106 // empty installments convert to 999 because PayJunction do not allow open end donation
107 if ($params['installments'] == "") {
108 $params['installments'] = "999";
111 // create recurring object
112 if ($params['is_recur'] == TRUE && $params['installments'] > 1) {
113 // schedule start date as today
114 // format: YYYY-MM-DD
115 $params['dc_schedule_start'] = date("Y-m-d");
118 $dc_schedule_create = $params['is_recur'];
119 $recurUnit = $params['frequency_unit'];
120 $recurInterval = $params['frequency_interval'];
121 $dc_schedule_start = $params['dc_schedule_start'];
123 // next payment in moneris required format
124 $startDate = date("Y/m/d", $next);
126 $numRecurs = $params['installments'];
129 'dc_schedule_create' => $dc_schedule_create,
130 // (day | week | month)
131 'recur_unit' => $recurUnit,
133 'start_date' => $startDate,
134 'num_recurs' => $numRecurs,
135 'start_now' => 'false',
136 'period' => $recurInterval,
137 'dc_schedule_start' => $dc_schedule_start,
138 'amount' => sprintf('%01.2f', $params['amount']),
141 $pjpgRecur = new pjpgRecur($recurArray);
143 $pjpgTxn->setRecur($pjpgRecur);
146 // create a pjpgRequest object passing the transaction object
147 $pjpgRequest = new pjpgRequest($pjpgTxn);
149 $pjpgHttpPost = new pjpgHttpsPost($pjpgRequest);
151 // get an pjpgResponse object
152 $pjpgResponse = $pjpgHttpPost->getPJpgResponse();
154 if (self
::isError($pjpgResponse)) {
155 return self
::error($pjpgResponse);
158 /* Check for application errors */
160 $result = self
::checkResult($pjpgResponse);
161 if (is_a($result, 'CRM_Core_Error')) {
166 $params['trxn_result_code'] = $pjpgResponse['dc_response_code'];
167 $params['trxn_id'] = $pjpgResponse['dc_transaction_id'];
168 $params['gross_amount'] = $params['amount'];
172 // end function doDirectPayment
175 * This function checks the PayJunction response code.
177 * @param array $response
181 public function isError(&$response) {
182 $responseCode = $response['dc_response_code'];
184 if ($responseCode == "00" ||
$responseCode == "85") {
194 * ignore for now, more elaborate error handling later.
199 public function &checkResult(&$response) {
204 * Get the value of a field if set.
206 * @param string $field
210 * value of the field, or empty string if the field is
213 public function _getParam($field) {
214 if (isset($this->_params
[$field])) {
215 return $this->_params
[$field];
227 public function &error($error = NULL) {
228 $e = CRM_Core_Error
::singleton();
230 $e->push($error['dc_response_code'],
232 $error['dc_response_message']
236 $e->push(9001, 0, NULL, "Unknown System Error.");
242 * Set a field to the specified value. Value must be a scalar (int,
243 * float, string, or boolean)
245 * @param string $field
246 * @param mixed $value
249 * false if value is not a scalar, true if successful
251 public function _setParam($field, $value) {
252 if (!is_scalar($value)) {
256 $this->_params
[$field] = $value;
261 * This function checks to see if we have the right config values.
264 * the error message if any
266 public function checkConfig() {
268 if (empty($this->_paymentProcessor
['user_name'])) {
269 $error[] = ts('Username is not set for this payment processor');
272 if (empty($this->_paymentProcessor
['password'])) {
273 $error[] = ts('Password is not set for this payment processor');
276 if (empty($this->_paymentProcessor
['url_site'])) {
277 $error[] = ts('Site URL is not set for this payment processor');
280 if (!empty($error)) {
281 return implode('<p>', $error);
289 // end class CRM_Core_Payment_PayJunction