forked from artfulrobot/uk.artfulrobot.civicrm.gocardless
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgocardless.php
263 lines (241 loc) · 8.44 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
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
<?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);
}
/**
* Complete a GoCardless redirect flow before we present the thank you page.
*
* - call GC API to complete the mandate.
* - find details of the contribution: how much, how often, day of month, 'name'
* - set up a GC Subscription.
* - set trxn_id to the subscription ID in the contribution table.
* - if recurring: set trxn_id, "In Progress", start date in contribution_recur table.
* - if membership: set membership end date to start date + interval.
*
*/
function gocardless_civicrm_buildForm( $formName, &$form ) {
if ($formName != 'CRM_Contribute_Form_Contribution_ThankYou' || empty($_GET['redirect_flow_id'])) {
// This form build has nothing to do with us.
return;
}
// We have a redirect_flow_id.
$redirect_flow_id = $_GET['redirect_flow_id'];
$sesh = CRM_Core_Session::singleton();
$sesh_store = $sesh->get('redirect_flows', 'GoCardless');
if (empty($sesh_store[$redirect_flow_id])) {
// When would this happen?
// - Back button.
// - Hacks?
// - Something else that lost the session.
//
// Anyway, in all cases let's assume that we are unable to proceed.
CRM_Core_Error::fatal('Sorry there was an error setting up your Direct Debit. This could be caused by your browser not allowing cookies.');
return;
}
// Validate the session_token.
if (empty($_GET['qfKey']) || empty($sesh_store[$redirect_flow_id]['session_token'])
|| $_GET['qfKey'] != $sesh_store[$redirect_flow_id]['session_token']) {
// @todo throw something that generates a server error 500 page.
CRM_Core_Error::fatal('Sorry, the session tokens did not match. This should not happen.');
return;
}
// Complete the redirect flow with GC.
try {
$params = [ 'redirect_flow_id' => $redirect_flow_id ] + $sesh_store[$redirect_flow_id];
$result = CRM_GoCardlessUtils::completeRedirectFlowCiviCore($params);
}
catch (Exception $e) {
CRM_Core_Error::fatal('Sorry there was an error setting up your Direct Debit. Please contact us so we can look into what went wrong.');
}
}
/**
* 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, NULL, array(
'label' => E::ts('The Page', array('domain' => 'uk.artfulrobot.civicrm.gocardless')),
'name' => 'the_page',
'url' => 'civicrm/the-page',
'permission' => 'access CiviReport,access CiviContribute',
'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'
);
}
}