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 class CRM_Core_Payment_PayJunction
extends CRM_Core_Payment
{
19 # (not used, implicit in the API, might need to convert?)
20 const CHARSET
= 'UFT-8';
23 * We only need one instance of this object. So we use the singleton
24 * pattern and cache the instance in this variable
28 static private $_singleton = NULL;
34 * The mode of operation: live or test.
36 * @param $paymentProcessor
38 * @return \CRM_Core_Payment_PayJunction
40 public function __construct($mode, &$paymentProcessor) {
41 //require PayJunction API library
42 require_once 'PayJunction/pjClasses.php';
45 $this->_paymentProcessor
= $paymentProcessor;
46 $this->_processorName
= ts('PayJunction');
50 * This function sends request and receives response from
51 * PayJunction payment process
53 * @param array $params
54 * Assoc array of input parameters for this transaction.
57 * the result in an nice formatted array (or an error object)
59 public function doDirectPayment(&$params) {
60 $logon = $this->_paymentProcessor
['user_name'];
61 $password = $this->_paymentProcessor
['password'];
62 $url_site = $this->_paymentProcessor
['url_site'];
64 // create pjpgCustInfo object
65 $pjpgCustInfo = new pjpgCustInfo();
67 $pjpgCustInfo->setEmail($params['email']);
71 "password" => $password,
72 "url_site" => $url_site,
73 "first_name" => $params['first_name'],
74 "last_name" => $params['last_name'],
75 "address" => $params['street_address'],
76 "city" => $params['city'],
77 "province" => $params['state_province'],
78 "postal_code" => $params['postal_code'],
79 "country" => $params['country'],
81 $pjpgCustInfo->setBilling($billing);
83 // create pjpgTransaction object
84 $my_orderid = $params['invoiceID'];
86 $expiry_string = sprintf('%04d%02d', $params['year'], $params['month']);
90 'order_id' => $my_orderid,
91 'amount' => sprintf('%01.2f', $params['amount']),
92 'pan' => $params['credit_card_number'],
93 'expdate' => $expiry_string,
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
176 * This function checks the PayJunction response code.
180 public function isError(&$response) {
181 $responseCode = $response['dc_response_code'];
183 if ($responseCode == "00" ||
$responseCode == "85") {
193 * ignore for now, more elaborate error handling later.
198 public function &checkResult(&$response) {
203 * Get the value of a field if set.
205 * @param string $field
209 * value of the field, or empty string if the field is
212 public function _getParam($field) {
213 if (isset($this->_params
[$field])) {
214 return $this->_params
[$field];
226 public function &error($error = NULL) {
227 $e = CRM_Core_Error
::singleton();
229 $e->push($error['dc_response_code'],
231 $error['dc_response_message']
235 $e->push(9001, 0, NULL, "Unknown System Error.");
241 * Set a field to the specified value. Value must be a scalar (int,
242 * float, string, or boolean)
244 * @param string $field
245 * @param mixed $value
248 * false if value is not a scalar, true if successful
250 public function _setParam($field, $value) {
251 if (!is_scalar($value)) {
255 $this->_params
[$field] = $value;
260 * This function checks to see if we have the right config values.
263 * the error message if any
265 public function checkConfig() {
267 if (empty($this->_paymentProcessor
['user_name'])) {
268 $error[] = ts('Username is not set for this payment processor');
271 if (empty($this->_paymentProcessor
['password'])) {
272 $error[] = ts('Password is not set for this payment processor');
275 if (empty($this->_paymentProcessor
['url_site'])) {
276 $error[] = ts('Site URL is not set for this payment processor');
279 if (!empty($error)) {
280 return implode('<p>', $error);
288 // end class CRM_Core_Payment_PayJunction