This repository has been archived by the owner on Jun 25, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 18
/
gocardless.php
229 lines (210 loc) · 6.94 KB
/
gocardless.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
<?php
use CRM_GoCardless_ExtensionUtil as E;
require_once 'gocardless.civix.php';
/**
* Implements hook_civicrm_config().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_config
*/
function gocardless_civicrm_config(&$config) {
_gocardless_civix_civicrm_config($config);
}
/**
* Implements hook_civicrm_xmlMenu().
*
* @param array $files
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_xmlMenu
*/
function gocardless_civicrm_xmlMenu(&$files) {
_gocardless_civix_civicrm_xmlMenu($files);
}
/**
* Implements hook_civicrm_install().
*
* We set up the payment processor type and payment instrument types here.
* (I tried to do this with `hook_civicrm_managed()` but failed because I need to relate the entities).
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_install
*/
function gocardless_civicrm_install() {
_gocardless_civix_civicrm_install();
}
/**
* Implements hook_civicrm_uninstall().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_uninstall
*/
function gocardless_civicrm_uninstall() {
_gocardless_civix_civicrm_uninstall();
// @todo remove direct_debit_gc payment instrument and GoCardless PaymentProcessorType if not in use.
}
/**
* Implements hook_civicrm_enable().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_enable
*/
function gocardless_civicrm_enable() {
_gocardless_civix_civicrm_enable();
}
/**
* Implements hook_civicrm_disable().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_disable
*/
function gocardless_civicrm_disable() {
_gocardless_civix_civicrm_disable();
}
/**
* Implements 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
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_upgrade
*/
function gocardless_civicrm_upgrade($op, CRM_Queue_Queue $queue = NULL) {
return _gocardless_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.
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_managed
*/
function gocardless_civicrm_managed(&$entities) {
_gocardless_civix_civicrm_managed($entities);
}
/**
* Implements hook_civicrm_caseTypes().
*
* Generate a list of case-types.
*
* @param array $caseTypes
*
* Note: This hook only runs in CiviCRM 4.4+.
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_caseTypes
*/
function gocardless_civicrm_caseTypes(&$caseTypes) {
_gocardless_civix_civicrm_caseTypes($caseTypes);
}
/**
* Implements hook_civicrm_angularModules().
*
* Generate a list of Angular modules.
*
* Note: This hook only runs in CiviCRM 4.5+. It may
* use features only available in v4.6+.
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_caseTypes
*/
function gocardless_civicrm_angularModules(&$angularModules) {
_gocardless_civix_civicrm_angularModules($angularModules);
}
/**
* Implements hook_civicrm_alterSettingsFolders().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_alterSettingsFolders
*/
function gocardless_civicrm_alterSettingsFolders(&$metaDataFolders = NULL) {
_gocardless_civix_civicrm_alterSettingsFolders($metaDataFolders);
}
/**
* Various intercepts.
*
*/
function gocardless_civicrm_buildForm($formName, &$form) {
if ($formName === 'CRM_Contribute_Form_Contribution_ThankYou') {
if (!empty($_GET['redirect_flow_id'])) {
// Looks like a GoCardless thank you page. Complete redirect flow.
CRM_GoCardlessUtils::handleContributeFormThanks();
}
}
elseif ($formName === 'CRM_Contribute_Form_Contribution_Main') {
CRM_GoCardlessUtils::handleContributeFormHacks();
}
}
/**
* Functions below this ship commented out. Uncomment as required.
*
/**
* Implements hook_civicrm_preProcess().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_preProcess
*
function gocardless_civicrm_preProcess($formName, &$form) {
} // */
/**
* Implements hook_civicrm_navigationMenu().
*
* @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_navigationMenu
*/
function gocardless_civicrm_navigationMenu(&$menu) {
_gocardless_civix_insert_navigation_menu($menu, 'Administer/CiviContribute', array(
'label' => E::ts('GoCardless Settings', array('domain' => 'uk.artfulrobot.civicrm.gocardless')),
'name' => 'gocardless_webhook_helper',
'url' => 'civicrm/a#/gocardless',
'permission' => 'administer payment processors',
'operator' => 'OR',
'separator' => 0,
));
_gocardless_civix_navigationMenu($menu);
}
/**
* Implements hook_civicrm_validateForm().
*
* @param string $formName
* @param array $fields
* @param array $files
* @param CRM_Core_Form $form
* @param array $errors
*/
function gocardless_civicrm_validateForm($formName, &$fields, &$files, &$form, &$errors) {
if ($formName === 'CRM_Admin_Form_PaymentProcessor') {
if (empty($fields['payment_processor_type_id'])) {
// huh?
return;
}
$payment_processor_name = civicrm_api3('PaymentProcessorType', 'getvalue', ['return' => 'name', 'id' => $fields['payment_processor_type_id']]);
if ('GoCardless' !== $payment_processor_name) {
// Not a GoCardless payment processor form.
return;
}
// Now we know it's a GoCardless payment processor form.
if ($fields['signature'] === $fields['test_signature']) {
$errors['test_signature'] = E::ts('Webhook secrets MUST be unique between test and live.');
}
}
}
/**
* Implementation of hook_civicrm_check
*
* Add a check to the status page/System.check that the payment instrument has a financial account.
* See https://github.com/artfulrobot/uk.artfulrobot.civicrm.gocardless/issues/51
*/
function gocardless_civicrm_check(&$messages) {
$result = civicrm_api3('OptionValue', 'getsingle', [
'option_group_id' => "payment_instrument",
'name' => "direct_debit_gc",
]);
$financial_account_id = CRM_Contribute_PseudoConstant::getRelationalFinancialAccount($result['id'], NULL, 'civicrm_option_value');
if (empty($financial_account_id)) {
$messages[] = new CRM_Utils_Check_Message(
'gocardless_missing_financial_account',
E::ts('Please visit Administer » CiviContribute » Payment Methods and edit '
. 'the entry called GoCardless Direct Debit. Select a suitable Financial Account '
. 'and press Save. Without this you may see errors like "No Payments found for '
. 'this contribution record".'),
E::ts('Missing Financial Account for GoCardless'),
\Psr\Log\LogLevel::WARNING,
'fa-flag'
);
}
}