-
Notifications
You must be signed in to change notification settings - Fork 0
/
omnipaymultiprocessor.php
245 lines (219 loc) · 7.99 KB
/
omnipaymultiprocessor.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
<?php
require_once 'omnipaymultiprocessor.civix.php';
/**
* Implementation of hook_civicrm_config
*
* @param $config
*/
function omnipaymultiprocessor_civicrm_config(&$config) {
_omnipaymultiprocessor_civix_civicrm_config($config);
}
/**
* Implementation of hook_civicrm_xmlMenu
*
* @param $files array(string)
*/
function omnipaymultiprocessor_civicrm_xmlMenu(&$files) {
_omnipaymultiprocessor_civix_civicrm_xmlMenu($files);
}
/**
* Implementation of hook_civicrm_install
*/
function omnipaymultiprocessor_civicrm_install() {
CRM_Core_DAO::executeQuery("
ALTER TABLE `civicrm_payment_processor`
CHANGE COLUMN `signature` `signature` LONGTEXT NULL DEFAULT NULL;
");
$logExists = CRM_Core_DAO::singleValueQuery("SHOW TABLES LIKE 'log_civicrm_payment_processor'");
if ($logExists) {
CRM_Core_DAO::executeQuery("
ALTER TABLE `log_civicrm_payment_processor`
CHANGE COLUMN `signature` `signature` LONGTEXT NULL DEFAULT NULL;
");
}
return _omnipaymultiprocessor_civix_civicrm_install();
}
/**
* Implementation of hook_civicrm_uninstall
*/
function omnipaymultiprocessor_civicrm_uninstall() {
return _omnipaymultiprocessor_civix_civicrm_uninstall();
}
/**
* Implementation of hook_civicrm_enable
*/
function omnipaymultiprocessor_civicrm_enable() {
return _omnipaymultiprocessor_civix_civicrm_enable();
}
/**
* Implementation of hook_civicrm_disable
*/
function omnipaymultiprocessor_civicrm_disable() {
return _omnipaymultiprocessor_civix_civicrm_disable();
}
/**
* Implementation of hook_civicrm_upgrade
*
* @param $op string, the type of operation being performed; 'check' or 'enqueue'
* @param $queue CRM_Queue_Queue, (for 'enqueue') the modifiable list of pending up upgrade tasks
*
* @return mixed
* Based on op. for 'check', returns array(boolean) (TRUE if upgrades are pending)
* for 'enqueue', returns void
*/
function omnipaymultiprocessor_civicrm_upgrade($op, CRM_Queue_Queue $queue = NULL) {
//@todo fix me - when I grow up I want to be a proper upgrade hook (or possibly removed since there should be no new installs requiring this)
CRM_Core_DAO::executeQuery("UPDATE civicrm_menu SET is_public = 1 WHERE path = 'civicrm/payment/details'");
return _omnipaymultiprocessor_civix_civicrm_upgrade($op, $queue);
}
/**
* Implements hook_civicrm_managed().
*
* Generate a list of entities to create/deactivate/delete when this module
* is installed, disabled, uninstalled.
*
* @param array $entities
*/
function omnipaymultiprocessor_civicrm_managed(&$entities) {
return _omnipaymultiprocessor_civix_civicrm_managed($entities);
}
/**
* @param $version
*
* @return bool
*/
function omnipaymultiprocessor__versionAtLeast($version) {
$codeVersion = explode('.', CRM_Utils_System::version());
if (version_compare($codeVersion[0] . '.' . $codeVersion[1], $version) >= 0) {
return TRUE;
}
return FALSE;
}
/**
* Implement buildForm hook to remove billing fields if elsewhere on the form.
*
* @param string $formName
* @param CRM_Contribute_Form_Contribution_Main|CRM_Event_Form_Registration_Register $form
*/
function omnipaymultiprocessor_civicrm_buildForm($formName, &$form) {
if ($formName == 'CRM_Admin_Form_PaymentProcessor') {
foreach (array('signature', 'test_signature') as $fieldName) {
if ($form->elementExists($fieldName)) {
$label = $form->_elements[$form->_elementIndex[$fieldName]]->_label;
$form->removeElement($fieldName);
$form->add('textarea', $fieldName,
$label,
array('rows' => 4, 'cols' => 40)
);
}
}
}
if (!method_exists('CRM_Core_Payment_Form', 'buildCreditCard')) {
//presumably we are on 4.6 & the following code is no longer required
return;
}
if (!omnipaymultiprocessor_is_credit_card_form($formName)
|| $form->_paymentProcessor['class_name'] != 'Payment_OmnipayMultiProcessor') {
return;
}
$paymentType = civicrm_api3('option_value', 'getsingle', array('value' => $form->_paymentProcessor['payment_type'], 'option_group_id' => 'payment_type'));
$form->assign('paymentTypeName', $paymentType['name']);
$paymentFields = omnipaymultiprocessor_get_valid_form_payment_fields($formName == 'CRM_Contribute_Form_Contribution_Main' ? 'contribute' : 'event', $form->_paymentProcessor, (empty($form->_paymentFields) ? array() : $form->_paymentFields));
if (!empty($paymentFields)) {
$form->assign('paymentFields', $paymentFields);
$form->assign('paymentTypeLabel', ts($paymentType['label'] . ' Information'));
}
else {
$form->assign('paymentFields', NULL);
$form->assign('paymentTypeLabel', NULL);
}
$billingDetailsFields = omnipaymultiprocessor_getBillingPersonalDetailsFields($form->_paymentProcessor);
//we trick CiviCRM into adding the credit card form so we can remove the parts we don't want (the credit card fields)
//for a transparent redirect like Cybersource
$billingMode = $form->_paymentProcessor['billing_mode'];
$form->_paymentProcessor['billing_mode'] = CRM_Core_Payment::BILLING_MODE_FORM;
CRM_Core_Payment_Form::buildCreditCard($form);
$form->_paymentProcessor['billing_mode'] = $billingMode;
//CiviCRM assumes that if it is Not a credit card it MUST be a direct debit & makes those required
$suppressedFields = omnipaymultiprocessor_get_suppressed_billing_fields((array) $billingDetailsFields, (array) $paymentFields, (array) $form->_paymentFields);
foreach ($suppressedFields as $suppressedField) {
$form->_paymentFields[$suppressedField]['is_required'] = FALSE;
}
$form->assign('suppressedFields', $suppressedFields);
$form->assign('billingDetailsFields', $billingDetailsFields);
CRM_Core_Region::instance('billing-block')->update('default', array(
'disabled' => TRUE,
));
CRM_Core_Region::instance('billing-block')->add(array(
'template' => 'SubstituteBillingBlock.tpl',
));
}
/**
* Get the billing fields we have suppressed
* @param array $profileFields
* @param integer $billingLocationID
*
* @return array
*/
function omnipaymultiprocessor_get_suppressed_billing_fields($billingDetailFields, $creditCardDetailsFields, $allFields) {
return array_keys(array_diff_key($allFields, array_flip($billingDetailFields + $creditCardDetailsFields)));
}
/**
* get billing fields
* note we should consider calling the payment processor for this information like we do for payment fields
* @param array $paymentProcessor
*
* @return array
*/
function omnipaymultiprocessor_getBillingPersonalDetailsFields($paymentProcessor) {
$processor = omnipaymultiprocessor_get_payment_processor_object('contribute', $paymentProcessor);
return $processor->getBillingBlockFields();
}
/**
* Get a list of the payment fields to display on the form.
*
* @param $mode
* @param $processor
* @param $formPaymentFields
*
* @return array
*/
function omnipaymultiprocessor_get_valid_form_payment_fields($mode, $processor, $formPaymentFields) {
$processor = omnipaymultiprocessor_get_payment_processor_object($mode, $processor);
$paymentFields = $processor->getPaymentFormFields();
return array_keys(array_intersect_key(array_fill_keys($paymentFields, 1), $formPaymentFields));
}
/**
* get a list of civicrm's defined direct debit fields - because CiviCRM hard-codes the expectation that if it's not credit card it's debit card
* we need to know these fields to hack around CiviCRM
*
* @return array
*/
function omnipaymultiprocessor_get_direct_debit_fields() {
return array(
'account_holder',
'bank_account_number',
'bank_identification_number',
'bank_name',
);
}
/**
* @param $mode
* @param $paymentProcessor
* @return CRM_Core_Payment_OmnipayMultiProcessor
*/
function omnipaymultiprocessor_get_payment_processor_object($mode, $paymentProcessor) {
return new CRM_Core_Payment_OmnipayMultiProcessor($mode, $paymentProcessor);
}
/**
* @param $formName
*
* @return bool
*/
function omnipaymultiprocessor_is_credit_card_form($formName) {
if ($formName == 'CRM_Contribute_Form_Contribution_Main' || $formName == 'CRM_Event_Form_Registration_Register'
) {
return TRUE;
}
return FALSE;
}