1
|
|
|
<?php |
|
|
|
|
2
|
|
|
/** |
3
|
|
|
* Misc Functions |
4
|
|
|
* |
5
|
|
|
* @package Give |
6
|
|
|
* @subpackage Functions |
7
|
|
|
* @copyright Copyright (c) 2016, WordImpress |
8
|
|
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License |
9
|
|
|
* @since 1.0 |
10
|
|
|
*/ |
11
|
|
|
|
12
|
|
|
// Exit if accessed directly |
13
|
|
|
if ( ! defined( 'ABSPATH' ) ) { |
14
|
|
|
exit; |
15
|
|
|
} |
16
|
|
|
|
17
|
|
|
/** |
18
|
|
|
* Is Test Mode |
19
|
|
|
* |
20
|
|
|
* @since 1.0 |
21
|
|
|
* @global $give_options |
22
|
|
|
* @return bool $ret True if return mode is enabled, false otherwise |
23
|
|
|
*/ |
24
|
|
|
function give_is_test_mode() { |
25
|
52 |
|
|
26
|
|
|
$ret = give_get_option('test_mode', false); |
27
|
52 |
|
|
28
|
|
|
return (bool) apply_filters( 'give_is_test_mode', $ret ); |
29
|
52 |
|
|
30
|
|
|
} |
31
|
|
|
|
32
|
|
|
/** |
33
|
|
|
* Get the set currency |
34
|
|
|
* |
35
|
|
|
* @since 1.0 |
36
|
|
|
* @return string The currency code |
37
|
|
|
*/ |
38
|
|
|
function give_get_currency() { |
39
|
55 |
|
|
40
|
55 |
|
$currency = give_get_option( 'currency', 'USD' ); |
41
|
|
|
|
42
|
55 |
|
return apply_filters( 'give_currency', $currency ); |
43
|
|
|
} |
44
|
|
|
|
45
|
|
|
/** |
46
|
|
|
* Get the set currency position |
47
|
|
|
* |
48
|
|
|
* @since 1.3.6 |
49
|
|
|
* |
50
|
|
|
* @return string The currency code |
51
|
|
|
*/ |
52
|
|
|
function give_get_currency_position() { |
53
|
1 |
|
|
54
|
1 |
|
$currency_pos = give_get_option( 'currency_position', 'before' ); |
55
|
|
|
|
56
|
1 |
|
return apply_filters( 'give_currency_position', $currency_pos ); |
57
|
|
|
} |
58
|
|
|
|
59
|
|
|
|
60
|
|
|
/** |
61
|
|
|
* Get Currencies |
62
|
|
|
* |
63
|
|
|
* @since 1.0 |
64
|
|
|
* @return array $currencies A list of the available currencies |
65
|
|
|
*/ |
66
|
|
|
|
67
|
|
|
function give_get_currencies() { |
68
|
|
|
$currencies = array( |
69
|
|
|
'USD' => esc_html__( 'US Dollars ($)', 'give' ), |
70
|
|
|
'EUR' => esc_html__( 'Euros (€)', 'give' ), |
71
|
|
|
'GBP' => esc_html__( 'Pounds Sterling (£)', 'give' ), |
72
|
|
|
'AUD' => esc_html__( 'Australian Dollars ($)', 'give' ), |
73
|
|
|
'BRL' => esc_html__( 'Brazilian Real (R$)', 'give' ), |
74
|
|
|
'CAD' => esc_html__( 'Canadian Dollars ($)', 'give' ), |
75
|
|
|
'CZK' => esc_html__( 'Czech Koruna (Kč)', 'give' ), |
76
|
|
|
'DKK' => esc_html__( 'Danish Krone (kr)', 'give' ), |
77
|
|
|
'HKD' => esc_html__( 'Hong Kong Dollar ($)', 'give' ), |
78
|
|
|
'HUF' => esc_html__( 'Hungarian Forint (Ft)', 'give' ), |
79
|
|
|
'ILS' => esc_html__( 'Israeli Shekel (₪)', 'give' ), |
80
|
|
|
'JPY' => esc_html__( 'Japanese Yen (¥)', 'give' ), |
81
|
|
|
'MYR' => esc_html__( 'Malaysian Ringgits (RM)', 'give' ), |
82
|
|
|
'MXN' => esc_html__( 'Mexican Peso ($)', 'give' ), |
83
|
|
|
'MAD' => esc_html__( 'Moroccan Dirham (.د.م)', 'give' ), |
84
|
|
|
'NZD' => esc_html__( 'New Zealand Dollar ($)', 'give' ), |
85
|
|
|
'NOK' => esc_html__( 'Norwegian Krone (Kr.)', 'give' ), |
86
|
|
|
'PHP' => esc_html__( 'Philippine Pesos (₱)', 'give' ), |
87
|
|
|
'PLN' => esc_html__( 'Polish Zloty (zł)', 'give' ), |
88
|
|
|
'SGD' => esc_html__( 'Singapore Dollar ($)', 'give' ), |
89
|
|
|
'KRW' => esc_html__( 'South Korean Won (₩)', 'give' ), |
90
|
|
|
'ZAR' => esc_html__( 'South African Rand (R)', 'give' ), |
91
|
|
|
'SEK' => esc_html__( 'Swedish Krona (kr)', 'give' ), |
92
|
|
|
'CHF' => esc_html__( 'Swiss Franc (CHF)', 'give' ), |
93
|
|
|
'TWD' => esc_html__( 'Taiwan New Dollars (NT$)', 'give' ), |
94
|
|
|
'THB' => esc_html__( 'Thai Baht (฿)', 'give' ), |
95
|
|
|
'INR' => esc_html__( 'Indian Rupee (₹)', 'give' ), |
96
|
|
|
'TRY' => esc_html__( 'Turkish Lira (₺)', 'give' ), |
97
|
|
|
'RIAL' => esc_html__( 'Iranian Rial (﷼)', 'give' ), |
98
|
|
|
'RUB' => esc_html__( 'Russian Rubles (руб)', 'give' ) |
99
|
|
|
); |
100
|
|
|
|
101
|
|
|
return apply_filters( 'give_currencies', $currencies ); |
102
|
|
|
} |
103
|
|
|
|
104
|
|
|
|
105
|
|
|
/** |
106
|
|
|
* Give Currency Symbol |
107
|
|
|
* |
108
|
|
|
* Given a currency determine the symbol to use. If no currency given, site default is used. If no symbol is determine, the currency string is returned. |
109
|
|
|
* |
110
|
|
|
* @since 1.0 |
111
|
|
|
* |
112
|
|
|
* @param string $currency The currency string |
113
|
|
|
* |
114
|
|
|
* @return string The symbol to use for the currency |
115
|
|
|
*/ |
116
|
|
|
function give_currency_symbol( $currency = '' ) { |
117
|
|
|
|
118
|
45 |
|
if ( empty( $currency ) ) { |
119
|
|
|
$currency = give_get_currency(); |
120
|
|
|
} |
121
|
|
|
switch ( $currency ) : |
122
|
45 |
|
case 'GBP' : |
123
|
|
|
$symbol = '£'; |
124
|
|
|
break; |
125
|
45 |
|
case 'BRL' : |
126
|
|
|
$symbol = 'R$'; |
127
|
|
|
break; |
128
|
45 |
|
case 'EUR' : |
129
|
|
|
$symbol = '€'; |
130
|
|
|
break; |
131
|
45 |
|
case 'NOK' : |
132
|
|
|
$symbol = 'Kr.'; |
133
|
|
|
break; |
134
|
45 |
|
case 'INR' : |
135
|
|
|
$symbol = '₹'; |
136
|
|
|
break; |
137
|
45 |
|
case 'USD' : |
138
|
45 |
|
case 'AUD' : |
139
|
45 |
|
case 'CAD' : |
140
|
45 |
|
case 'HKD' : |
141
|
45 |
|
case 'MXN' : |
142
|
45 |
|
case 'SGD' : |
143
|
45 |
|
$symbol = '$'; |
144
|
45 |
|
break; |
145
|
|
|
case 'JPY' : |
146
|
|
|
$symbol = '¥'; |
147
|
|
|
break; |
148
|
|
|
case 'THB' : |
149
|
|
|
$symbol = '฿'; |
150
|
|
|
break; |
151
|
|
|
case 'TRY' : |
152
|
|
|
$symbol = '₺'; |
153
|
|
|
break; |
154
|
|
|
case 'TWD' : |
155
|
|
|
$symbol = 'NT$'; |
156
|
|
|
break; |
157
|
|
|
case 'ILS' : |
158
|
|
|
$symbol = '₪'; |
159
|
|
|
break; |
160
|
|
|
case 'RIAL' : |
161
|
|
|
$symbol = '﷼'; |
162
|
|
|
break; |
163
|
|
|
case 'RUB' : |
164
|
|
|
$symbol = 'руб'; |
165
|
|
|
break; |
166
|
|
|
case 'DKK' : |
167
|
|
|
case 'SEK' : |
168
|
|
|
$symbol = 'kr'; |
169
|
|
|
break; |
170
|
|
|
case 'PLN' : |
171
|
|
|
$symbol = 'zł'; |
172
|
|
|
break; |
173
|
|
|
case 'PHP' : |
174
|
|
|
$symbol = '₱'; |
175
|
|
|
break; |
176
|
|
|
case 'MYR' : |
177
|
|
|
$symbol = 'RM'; |
178
|
|
|
break; |
179
|
|
|
case 'HUF' : |
180
|
|
|
$symbol = 'Ft'; |
181
|
|
|
break; |
182
|
|
|
case 'CZK' : |
183
|
|
|
$symbol = 'Kč'; |
184
|
|
|
break; |
185
|
|
|
case 'KRW' : |
186
|
|
|
$symbol = '₩'; |
187
|
|
|
break; |
188
|
|
|
case 'ZAR' : |
189
|
|
|
$symbol = 'R'; |
190
|
|
|
break; |
191
|
|
|
case 'MAD' : |
192
|
|
|
$symbol = '.د.م'; |
193
|
|
|
break; |
194
|
|
|
default : |
195
|
|
|
$symbol = $currency; |
196
|
|
|
break; |
197
|
|
|
endswitch; |
198
|
|
|
|
199
|
|
|
|
200
|
45 |
|
return apply_filters( 'give_currency_symbol', $symbol, $currency ); |
201
|
|
|
} |
202
|
|
|
|
203
|
|
|
|
204
|
|
|
/** |
205
|
|
|
* Get the current page URL |
206
|
|
|
* |
207
|
|
|
* @since 1.0 |
208
|
|
|
* @return string $current_url Current page URL |
209
|
|
|
*/ |
210
|
|
|
function give_get_current_page_url() { |
211
|
|
|
|
212
|
6 |
|
if ( is_front_page() ) { |
213
|
|
|
$current_url = home_url( '/' ); |
214
|
|
|
} else { |
215
|
6 |
|
$current_url = set_url_scheme( 'http://' . $_SERVER['HTTP_HOST'] . untrailingslashit( $_SERVER['REQUEST_URI'] ) ); |
216
|
|
|
} |
217
|
|
|
|
218
|
6 |
|
return apply_filters( 'give_get_current_page_url', esc_url( $current_url ) ); |
219
|
|
|
} |
220
|
|
|
|
221
|
|
|
|
222
|
|
|
/** |
223
|
|
|
* Verify credit card numbers live? |
224
|
|
|
* |
225
|
|
|
* @since 1.0 |
226
|
|
|
* @global $give_options |
227
|
|
|
* @return bool $ret True is verify credit cards is live |
228
|
|
|
*/ |
229
|
|
|
function give_is_cc_verify_enabled() { |
230
|
|
|
|
231
|
|
|
$ret = true; |
232
|
|
|
|
233
|
|
|
/* |
234
|
|
|
* Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards |
235
|
|
|
* Enable if using more than one gateway if they aren't both PayPal and manual, again assuming credit card usage |
236
|
|
|
*/ |
237
|
|
|
$gateways = give_get_enabled_payment_gateways(); |
238
|
|
|
|
239
|
|
|
if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) { |
240
|
|
|
$ret = true; |
241
|
|
|
} else if ( count( $gateways ) == 1 ) { |
242
|
|
|
$ret = false; |
243
|
|
|
} else if ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) { |
244
|
|
|
$ret = false; |
245
|
|
|
} |
246
|
|
|
|
247
|
|
|
return (bool) apply_filters( 'give_verify_credit_cards', $ret ); |
248
|
|
|
} |
249
|
|
|
|
250
|
|
|
/** |
251
|
|
|
* Retrieve timezone |
252
|
|
|
* |
253
|
|
|
* @since 1.0 |
254
|
|
|
* @return string $timezone The timezone ID |
255
|
|
|
*/ |
256
|
|
|
function give_get_timezone_id() { |
257
|
|
|
|
258
|
|
|
// if site timezone string exists, return it |
259
|
|
|
if ( $timezone = get_option( 'timezone_string' ) ) { |
260
|
|
|
return $timezone; |
261
|
|
|
} |
262
|
|
|
|
263
|
|
|
// get UTC offset, if it isn't set return UTC |
264
|
|
|
if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) { |
265
|
|
|
return 'UTC'; |
266
|
|
|
} |
267
|
|
|
|
268
|
|
|
// attempt to guess the timezone string from the UTC offset |
269
|
|
|
$timezone = timezone_name_from_abbr( '', $utc_offset ); |
270
|
|
|
|
271
|
|
|
// last try, guess timezone string manually |
272
|
|
|
if ( $timezone === false ) { |
273
|
|
|
|
274
|
|
|
$is_dst = date( 'I' ); |
275
|
|
|
|
276
|
|
|
foreach ( timezone_abbreviations_list() as $abbr ) { |
277
|
|
|
foreach ( $abbr as $city ) { |
278
|
|
|
if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) { |
279
|
|
|
return $city['timezone_id']; |
280
|
|
|
} |
281
|
|
|
} |
282
|
|
|
} |
283
|
|
|
} |
284
|
|
|
|
285
|
|
|
// fallback |
286
|
|
|
return 'UTC'; |
287
|
|
|
} |
288
|
|
|
|
289
|
|
|
|
290
|
|
|
/** |
291
|
|
|
* Get User IP |
292
|
|
|
* |
293
|
|
|
* Returns the IP address of the current visitor |
294
|
|
|
* |
295
|
|
|
* @since 1.0 |
296
|
|
|
* @return string $ip User's IP address |
297
|
|
|
*/ |
298
|
|
|
function give_get_ip() { |
299
|
|
|
|
300
|
52 |
|
$ip = '127.0.0.1'; |
301
|
|
|
|
302
|
52 |
|
if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) { |
303
|
|
|
//check ip from share internet |
304
|
|
|
$ip = $_SERVER['HTTP_CLIENT_IP']; |
305
|
52 |
|
} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) { |
306
|
|
|
//to check ip is pass from proxy |
307
|
|
|
$ip = $_SERVER['HTTP_X_FORWARDED_FOR']; |
308
|
52 |
|
} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) { |
309
|
52 |
|
$ip = $_SERVER['REMOTE_ADDR']; |
310
|
52 |
|
} |
311
|
|
|
|
312
|
52 |
|
return apply_filters( 'give_get_ip', $ip ); |
313
|
|
|
} |
314
|
|
|
|
315
|
|
|
|
316
|
|
|
/** |
317
|
|
|
* Store Donation Data in Sessions |
318
|
|
|
* |
319
|
|
|
* Used for storing info about donation |
320
|
|
|
* |
321
|
|
|
* @since 1.0 |
322
|
|
|
* |
323
|
|
|
* @param $purchase_data |
324
|
|
|
* |
325
|
|
|
* @uses Give()->session->set() |
326
|
|
|
*/ |
327
|
|
|
function give_set_purchase_session( $purchase_data = array() ) { |
328
|
|
|
Give()->session->set( 'give_purchase', $purchase_data ); |
329
|
|
|
Give()->session->set( 'give_email', $purchase_data['user_email'] ); |
330
|
|
|
} |
331
|
|
|
|
332
|
|
|
/** |
333
|
|
|
* Retrieve Donation Data from Session |
334
|
|
|
* |
335
|
|
|
* Used for retrieving info about donation |
336
|
|
|
* after completing a donation |
337
|
|
|
* |
338
|
|
|
* @since 1.0 |
339
|
|
|
* @uses Give()->session->get() |
340
|
|
|
* @return mixed array | false |
341
|
|
|
*/ |
342
|
|
|
function give_get_purchase_session() { |
343
|
|
|
return Give()->session->get( 'give_purchase' ); |
344
|
|
|
} |
345
|
|
|
|
346
|
|
|
/** |
347
|
|
|
* Get Donation Summary |
348
|
|
|
* |
349
|
|
|
* Retrieves the donation summary. |
350
|
|
|
* |
351
|
|
|
* @since 1.0 |
352
|
|
|
* |
353
|
|
|
* @param array $purchase_data |
354
|
|
|
* @param bool $email |
355
|
|
|
* |
356
|
|
|
* @return string |
357
|
|
|
*/ |
358
|
|
|
function give_get_purchase_summary( $purchase_data, $email = true ) { |
359
|
|
|
$summary = ''; |
360
|
|
|
|
361
|
|
|
if ( $email ) { |
362
|
|
|
$summary .= $purchase_data['user_email'] . ' - '; |
363
|
|
|
} |
364
|
|
|
|
365
|
|
|
$summary .= get_the_title( $purchase_data['post_data']['give-form-id'] ); |
366
|
|
|
|
367
|
|
|
return $summary; |
368
|
|
|
} |
369
|
|
|
|
370
|
|
|
|
371
|
|
|
/** |
372
|
|
|
* Get user host |
373
|
|
|
* |
374
|
|
|
* Returns the webhost this site is using if possible |
375
|
|
|
* |
376
|
|
|
* @since 1.0 |
377
|
|
|
* @return string $host if detected, false otherwise |
378
|
|
|
*/ |
379
|
|
|
function give_get_host() { |
380
|
|
|
$host = false; |
381
|
|
|
|
382
|
|
|
if ( defined( 'WPE_APIKEY' ) ) { |
383
|
|
|
$host = 'WP Engine'; |
384
|
|
|
} elseif ( defined( 'PAGELYBIN' ) ) { |
385
|
|
|
$host = 'Pagely'; |
386
|
|
|
} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) { |
387
|
|
|
$host = 'ICDSoft'; |
388
|
|
|
} elseif ( DB_HOST == 'mysqlv5' ) { |
389
|
|
|
$host = 'NetworkSolutions'; |
390
|
|
|
} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) { |
391
|
|
|
$host = 'iPage'; |
392
|
|
|
} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) { |
393
|
|
|
$host = 'IPower'; |
394
|
|
|
} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) { |
395
|
|
|
$host = 'MediaTemple Grid'; |
396
|
|
|
} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) { |
397
|
|
|
$host = 'pair Networks'; |
398
|
|
|
} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) { |
399
|
|
|
$host = 'Rackspace Cloud'; |
400
|
|
|
} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) { |
401
|
|
|
$host = 'SysFix.eu Power Hosting'; |
402
|
|
|
} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) { |
403
|
|
|
$host = 'Flywheel'; |
404
|
|
|
} else { |
405
|
|
|
// Adding a general fallback for data gathering |
406
|
|
|
$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME']; |
407
|
|
|
} |
408
|
|
|
|
409
|
|
|
return $host; |
410
|
|
|
} |
411
|
|
|
|
412
|
|
|
|
413
|
|
|
/** |
414
|
|
|
* Check site host |
415
|
|
|
* |
416
|
|
|
* @since 1.0 |
417
|
|
|
* |
418
|
|
|
* @param bool /string $host The host to check |
419
|
|
|
* |
420
|
|
|
* @return bool true if host matches, false if not |
421
|
|
|
*/ |
422
|
|
|
function give_is_host( $host = false ) { |
423
|
|
|
|
424
|
|
|
$return = false; |
425
|
|
|
|
426
|
|
|
if ( $host ) { |
427
|
|
|
$host = str_replace( ' ', '', strtolower( $host ) ); |
428
|
|
|
|
429
|
|
|
switch ( $host ) { |
430
|
|
|
case 'wpengine': |
431
|
|
|
if ( defined( 'WPE_APIKEY' ) ) { |
432
|
|
|
$return = true; |
433
|
|
|
} |
434
|
|
|
break; |
435
|
|
|
case 'pagely': |
436
|
|
|
if ( defined( 'PAGELYBIN' ) ) { |
437
|
|
|
$return = true; |
438
|
|
|
} |
439
|
|
|
break; |
440
|
|
|
case 'icdsoft': |
441
|
|
|
if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) { |
442
|
|
|
$return = true; |
443
|
|
|
} |
444
|
|
|
break; |
445
|
|
|
case 'networksolutions': |
446
|
|
|
if ( DB_HOST == 'mysqlv5' ) { |
447
|
|
|
$return = true; |
448
|
|
|
} |
449
|
|
|
break; |
450
|
|
|
case 'ipage': |
451
|
|
|
if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) { |
452
|
|
|
$return = true; |
453
|
|
|
} |
454
|
|
|
break; |
455
|
|
|
case 'ipower': |
456
|
|
|
if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) { |
457
|
|
|
$return = true; |
458
|
|
|
} |
459
|
|
|
break; |
460
|
|
|
case 'mediatemplegrid': |
461
|
|
|
if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) { |
462
|
|
|
$return = true; |
463
|
|
|
} |
464
|
|
|
break; |
465
|
|
|
case 'pairnetworks': |
466
|
|
|
if ( strpos( DB_HOST, '.pair.com' ) !== false ) { |
467
|
|
|
$return = true; |
468
|
|
|
} |
469
|
|
|
break; |
470
|
|
|
case 'rackspacecloud': |
471
|
|
|
if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) { |
472
|
|
|
$return = true; |
473
|
|
|
} |
474
|
|
|
break; |
475
|
|
|
case 'sysfix.eu': |
476
|
|
|
case 'sysfix.eupowerhosting': |
477
|
|
|
if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) { |
478
|
|
|
$return = true; |
479
|
|
|
} |
480
|
|
|
break; |
481
|
|
|
case 'flywheel': |
482
|
|
|
if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) { |
483
|
|
|
$return = true; |
484
|
|
|
} |
485
|
|
|
break; |
486
|
|
|
default: |
487
|
|
|
$return = false; |
488
|
|
|
} |
489
|
|
|
} |
490
|
|
|
|
491
|
|
|
return $return; |
492
|
|
|
} |
493
|
|
|
|
494
|
|
|
/** |
495
|
|
|
* Marks a function as deprecated and informs when it has been used. |
496
|
|
|
* |
497
|
|
|
* There is a hook give_deprecated_function_run that will be called that can be used |
498
|
|
|
* to get the backtrace up to what file and function called the deprecated |
499
|
|
|
* function. |
500
|
|
|
* |
501
|
|
|
* The current behavior is to trigger a user error if WP_DEBUG is true. |
502
|
|
|
* |
503
|
|
|
* This function is to be used in every function that is deprecated. |
504
|
|
|
* |
505
|
|
|
* @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead, |
506
|
|
|
* and the version the function was deprecated in. |
507
|
|
|
* @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do |
508
|
|
|
* trigger or false to not trigger error. |
509
|
|
|
* |
510
|
|
|
* @param string $function The function that was called. |
511
|
|
|
* @param string $version The plugin version that deprecated the function. |
512
|
|
|
* @param string $replacement Optional. The function that should have been called. |
513
|
|
|
* @param array $backtrace Optional. Contains stack backtrace of deprecated function. |
514
|
|
|
*/ |
515
|
|
|
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) { |
516
|
1 |
|
|
517
|
|
|
/** |
518
|
1 |
|
* Fires while give deprecated function call occurs. |
519
|
|
|
* |
520
|
|
|
* Allow you to hook to deprecated function call. |
521
|
1 |
|
* |
522
|
|
|
* @since 1.0 |
523
|
|
|
* |
524
|
|
|
* @param string $function The function that was called. |
525
|
|
|
* @param string $replacement Optional. The function that should have been called. |
526
|
|
|
* @param string $version The plugin version that deprecated the function. |
527
|
|
|
*/ |
528
|
|
|
do_action( 'give_deprecated_function_run', $function, $replacement, $version ); |
529
|
|
|
|
530
|
|
|
$show_errors = current_user_can( 'manage_options' ); |
531
|
|
|
|
532
|
1 |
|
// Allow plugin to filter the output error trigger |
533
|
|
|
if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) { |
534
|
|
|
if ( ! is_null( $replacement ) ) { |
535
|
|
|
trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) ); |
536
|
|
|
trigger_error( print_r( $backtrace, 1 ) ); // Limited to previous 1028 characters, but since we only need to move back 1 in stack that should be fine. |
537
|
|
|
// Alternatively we could dump this to a file. |
538
|
|
|
} else { |
539
|
|
|
trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) ); |
540
|
|
|
trigger_error( print_r( $backtrace, 1 ) );// Limited to previous 1028 characters, but since we only need to move back 1 in stack that should be fine. |
541
|
|
|
// Alternatively we could dump this to a file. |
542
|
|
|
} |
543
|
|
|
} |
544
|
|
|
} |
545
|
|
|
|
546
|
|
|
/** |
547
|
|
|
* Give Get Admin ID |
548
|
|
|
* |
549
|
|
|
* Helper function to return the ID of the post for admin usage |
550
|
|
|
* |
551
|
|
|
* @return string $post_id |
552
|
|
|
*/ |
553
|
|
|
function give_get_admin_post_id() { |
554
|
|
|
$post_id = isset( $_GET['post'] ) ? $_GET['post'] : null; |
555
|
|
|
if ( ! $post_id && isset( $_POST['post_id'] ) ) { |
556
|
|
|
$post_id = $_POST['post_id']; |
557
|
|
|
} |
558
|
|
|
|
559
|
|
|
return $post_id; |
560
|
|
|
} |
561
|
|
|
|
562
|
|
|
/** |
563
|
|
|
* Get PHP Arg Separator Output |
564
|
|
|
* |
565
|
|
|
* @since 1.0 |
566
|
|
|
* @return string Arg separator output |
567
|
|
|
*/ |
568
|
|
|
function give_get_php_arg_separator_output() { |
569
|
|
|
return ini_get( 'arg_separator.output' ); |
570
|
|
|
} |
571
|
|
|
|
572
|
|
|
|
573
|
|
|
/** |
574
|
|
|
* Month Num To Name |
575
|
|
|
* |
576
|
|
|
* Takes a month number and returns the name three letter name of it. |
577
|
|
|
* |
578
|
|
|
* @since 1.0 |
579
|
|
|
* |
580
|
|
|
* @param int $n |
581
|
|
|
* |
582
|
|
|
* @return string Short month name |
583
|
|
|
*/ |
584
|
|
|
function give_month_num_to_name( $n ) { |
585
|
|
|
$timestamp = mktime( 0, 0, 0, $n, 1, 2005 ); |
586
|
|
|
|
587
|
|
|
return date_i18n( "M", $timestamp ); |
588
|
|
|
} |
589
|
|
|
|
590
|
|
|
|
591
|
|
|
/** |
592
|
|
|
* Checks whether function is disabled. |
593
|
|
|
* |
594
|
|
|
* @since 1.0 |
595
|
|
|
* |
596
|
|
|
* @param string $function Name of the function. |
597
|
|
|
* |
598
|
|
|
* @return bool Whether or not function is disabled. |
599
|
|
|
*/ |
600
|
|
|
function give_is_func_disabled( $function ) { |
601
|
|
|
$disabled = explode( ',', ini_get( 'disable_functions' ) ); |
602
|
|
|
|
603
|
|
|
return in_array( $function, $disabled ); |
604
|
|
|
} |
605
|
|
|
|
606
|
|
|
|
607
|
|
|
/** |
608
|
|
|
* Give Newsletter |
609
|
|
|
* |
610
|
|
|
* Returns the main Give newsletter form |
611
|
|
|
*/ |
612
|
|
|
function give_get_newsletter() { ?> |
613
|
|
|
|
614
|
|
|
<div class="give-newsletter-form-wrap"> |
615
|
|
|
|
616
|
|
|
<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&id=12a081aa13" method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate" target="_blank" novalidate> |
617
|
|
|
<div class="give-newsletter-confirmation"> |
618
|
|
|
<p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p> |
619
|
|
|
</div> |
620
|
|
|
|
621
|
|
|
<table class="form-table give-newsletter-form"> |
622
|
|
|
<tr valign="middle"> |
623
|
|
|
<td> |
624
|
|
|
<label for="mce-EMAIL" class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label> |
625
|
|
|
<input type="email" name="EMAIL" id="mce-EMAIL" placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>" class="required email" value=""> |
626
|
|
|
</td> |
627
|
|
|
<td> |
628
|
|
|
<label for="mce-FNAME" class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label> |
629
|
|
|
<input type="text" name="FNAME" id="mce-FNAME" placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value=""> |
630
|
|
|
</td> |
631
|
|
|
<td> |
632
|
|
|
<label for="mce-LNAME" class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label> |
633
|
|
|
<input type="text" name="LNAME" id="mce-LNAME" placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value=""> |
634
|
|
|
</td> |
635
|
|
|
<td> |
636
|
|
|
<input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button" value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>"> |
637
|
|
|
</td> |
638
|
|
|
</tr> |
639
|
|
|
</table> |
640
|
|
|
</form> |
641
|
|
|
|
642
|
|
|
<div style="position: absolute; left: -5000px;"> |
643
|
|
|
<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value=""> |
644
|
|
|
</div> |
645
|
|
|
|
646
|
|
|
</div> |
647
|
|
|
|
648
|
|
|
<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script> |
649
|
|
|
<script type='text/javascript'>(function ($) { |
650
|
|
|
window.fnames = new Array(); |
651
|
|
|
window.ftypes = new Array(); |
652
|
|
|
fnames[0] = 'EMAIL'; |
653
|
|
|
ftypes[0] = 'email'; |
654
|
|
|
fnames[1] = 'FNAME'; |
655
|
|
|
ftypes[1] = 'text'; |
656
|
|
|
fnames[2] = 'LNAME'; |
657
|
|
|
ftypes[2] = 'text'; |
658
|
|
|
|
659
|
|
|
//Successful submission |
660
|
|
|
$('form[name="mc-embedded-subscribe-form"]').on('submit', function () { |
661
|
|
|
|
662
|
|
|
var email_field = $(this).find('#mce-EMAIL').val(); |
663
|
|
|
if (!email_field) { |
664
|
|
|
return false; |
665
|
|
|
} |
666
|
|
|
$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp(); |
667
|
|
|
$(this).find('.give-newsletter-form').hide(); |
668
|
|
|
|
669
|
|
|
}); |
670
|
|
|
|
671
|
|
|
|
672
|
|
|
}(jQuery)); |
673
|
|
|
var $mcj = jQuery.noConflict(true); |
674
|
|
|
|
675
|
|
|
|
676
|
|
|
</script> |
677
|
|
|
<!--End mc_embed_signup--> |
678
|
|
|
|
679
|
|
|
<?php } |
680
|
|
|
|
681
|
|
|
|
682
|
|
|
/** |
683
|
|
|
* Social Media Like Buttons |
684
|
|
|
* |
685
|
|
|
* Various social media elements to Give |
686
|
|
|
*/ |
687
|
|
|
function give_social_media_elements() { |
688
|
|
|
?> |
689
|
|
|
|
690
|
|
|
<div class="social-items-wrap"> |
691
|
|
|
|
692
|
|
|
<iframe src="//www.facebook.com/plugins/like.php?href=https%3A%2F%2Fwww.facebook.com%2Fwpgive&send=false&layout=button_count&width=100&show_faces=false&font&colorscheme=light&action=like&height=21&appId=220596284639969" scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:100px; height:21px;" allowTransparency="true"></iframe> |
693
|
|
|
|
694
|
|
|
<a href="https://twitter.com/givewp" class="twitter-follow-button" data-show-count="false"><?php |
695
|
|
|
printf( |
696
|
|
|
/* translators: %s: Give twitter user @givewp */ |
697
|
|
|
esc_html_e( 'Follow %s', 'give' ), |
698
|
|
|
'@givewp' |
699
|
|
|
); |
700
|
|
|
?></a> |
701
|
|
|
<script>!function (d, s, id) { |
702
|
|
|
var js, fjs = d.getElementsByTagName(s)[0], p = /^http:/.test(d.location) ? 'http' : 'https'; |
703
|
|
|
if (!d.getElementById(id)) { |
704
|
|
|
js = d.createElement(s); |
705
|
|
|
js.id = id; |
706
|
|
|
js.src = p + '://platform.twitter.com/widgets.js'; |
707
|
|
|
fjs.parentNode.insertBefore(js, fjs); |
708
|
|
|
} |
709
|
|
|
}(document, 'script', 'twitter-wjs'); |
710
|
|
|
</script> |
711
|
|
|
|
712
|
|
|
</div> |
713
|
|
|
<!--/.social-items-wrap --> |
714
|
|
|
|
715
|
|
|
<?php |
716
|
|
|
} |
717
|
|
|
|
718
|
|
|
|
719
|
|
|
/** |
720
|
|
|
* Create SVG library function |
721
|
|
|
* |
722
|
|
|
* @param $icon |
723
|
|
|
* |
724
|
|
|
* @return mixed |
725
|
|
|
*/ |
726
|
|
|
function give_svg_icons( $icon ) { |
727
|
|
|
|
728
|
|
|
// Store your SVGs in an associative array |
729
|
|
|
$svgs = array( |
730
|
|
|
'microphone' => '', |
731
|
|
|
'alert' => "", |
732
|
|
|
'placemark' => '', |
733
|
|
|
'give_grey' => '', |
734
|
|
|
'give_cpt_icon' => '', |
735
|
|
|
); |
736
|
|
|
|
737
|
|
|
// Return the chosen icon's SVG string |
738
|
|
|
return $svgs[ $icon ]; |
739
|
|
|
} |
740
|
|
|
|
741
|
|
|
/** |
742
|
|
|
* Modify Admin Nav Menu Label |
743
|
|
|
* |
744
|
|
|
* @since 1.3 |
745
|
|
|
* |
746
|
|
|
* @param $post_type |
747
|
|
|
* |
748
|
|
|
* @return mixed |
749
|
|
|
*/ |
750
|
|
|
function modify_nav_menu_meta_box_object( $post_type ) { |
751
|
|
|
if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) { |
752
|
|
|
$post_type->labels->name = esc_html__( 'Donation Forms', 'give' ); |
753
|
|
|
} |
754
|
|
|
|
755
|
|
|
return $post_type; |
756
|
|
|
} |
757
|
|
|
|
758
|
|
|
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' ); |
759
|
|
|
|
760
|
|
|
|
761
|
|
|
/** |
762
|
|
|
* Array_column backup usage |
763
|
|
|
* |
764
|
|
|
* This file is part of the array_column library. |
765
|
|
|
* |
766
|
|
|
* @since : 1.3.0.1 |
767
|
|
|
* |
768
|
|
|
* @copyright Copyright (c) Ben Ramsey (http://benramsey.com) |
769
|
|
|
* @license http://opensource.org/licenses/MIT MIT |
770
|
|
|
*/ |
771
|
|
|
|
772
|
|
|
if ( ! function_exists( 'array_column' ) ) { |
773
|
|
|
/** |
774
|
|
|
* Returns the values from a single column of the input array, identified by |
775
|
|
|
* the $columnKey. |
776
|
|
|
* |
777
|
|
|
* Optionally, you may provide an $indexKey to index the values in the returned |
778
|
|
|
* array by the values from the $indexKey column in the input array. |
779
|
|
|
* |
780
|
|
|
* @param array $input A multi-dimensional array (record set) from which to pull |
781
|
|
|
* a column of values. |
782
|
|
|
* @param mixed $columnKey The column of values to return. This value may be the |
783
|
|
|
* integer key of the column you wish to retrieve, or it |
784
|
|
|
* may be the string key name for an associative array. |
785
|
|
|
* @param mixed $indexKey (Optional.) The column to use as the index/keys for |
786
|
|
|
* the returned array. This value may be the integer key |
787
|
|
|
* of the column, or it may be the string key name. |
788
|
|
|
* |
789
|
|
|
* @return array |
790
|
|
|
*/ |
791
|
|
|
function array_column( $input = null, $columnKey = null, $indexKey = null ) { |
|
|
|
|
792
|
|
|
// Using func_get_args() in order to check for proper number of |
793
|
|
|
// parameters and trigger errors exactly as the built-in array_column() |
794
|
|
|
// does in PHP 5.5. |
795
|
|
|
$argc = func_num_args(); |
796
|
|
|
$params = func_get_args(); |
797
|
|
|
|
798
|
|
|
if ( $argc < 2 ) { |
799
|
|
|
trigger_error( "array_column() expects at least 2 parameters, {$argc} given", E_USER_WARNING ); |
800
|
|
|
|
801
|
|
|
return null; |
802
|
|
|
} |
803
|
|
|
|
804
|
|
|
if ( ! is_array( $params[0] ) ) { |
805
|
|
|
trigger_error( |
806
|
|
|
'array_column() expects parameter 1 to be array, ' . gettype( $params[0] ) . ' given', |
807
|
|
|
E_USER_WARNING |
808
|
|
|
); |
809
|
|
|
|
810
|
|
|
return null; |
811
|
|
|
} |
812
|
|
|
|
813
|
|
|
if ( ! is_int( $params[1] ) |
814
|
|
|
&& ! is_float( $params[1] ) |
815
|
|
|
&& ! is_string( $params[1] ) |
816
|
|
|
&& $params[1] !== null |
817
|
|
|
&& ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) ) |
818
|
|
|
) { |
819
|
|
|
trigger_error( 'array_column(): The column key should be either a string or an integer', E_USER_WARNING ); |
820
|
|
|
|
821
|
|
|
return false; |
822
|
|
|
} |
823
|
|
|
|
824
|
|
|
if ( isset( $params[2] ) |
825
|
|
|
&& ! is_int( $params[2] ) |
826
|
|
|
&& ! is_float( $params[2] ) |
827
|
|
|
&& ! is_string( $params[2] ) |
828
|
|
|
&& ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) ) |
829
|
|
|
) { |
830
|
|
|
trigger_error( 'array_column(): The index key should be either a string or an integer', E_USER_WARNING ); |
831
|
|
|
|
832
|
|
|
return false; |
833
|
|
|
} |
834
|
|
|
|
835
|
|
|
$paramsInput = $params[0]; |
836
|
|
|
$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null; |
837
|
|
|
|
838
|
|
|
$paramsIndexKey = null; |
839
|
|
|
if ( isset( $params[2] ) ) { |
840
|
|
|
if ( is_float( $params[2] ) || is_int( $params[2] ) ) { |
841
|
|
|
$paramsIndexKey = (int) $params[2]; |
842
|
|
|
} else { |
843
|
|
|
$paramsIndexKey = (string) $params[2]; |
844
|
|
|
} |
845
|
|
|
} |
846
|
|
|
|
847
|
|
|
$resultArray = array(); |
848
|
|
|
|
849
|
|
|
foreach ( $paramsInput as $row ) { |
850
|
|
|
$key = $value = null; |
851
|
|
|
$keySet = $valueSet = false; |
852
|
|
|
|
853
|
|
|
if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) { |
854
|
|
|
$keySet = true; |
855
|
|
|
$key = (string) $row[ $paramsIndexKey ]; |
856
|
|
|
} |
857
|
|
|
|
858
|
|
|
if ( $paramsColumnKey === null ) { |
859
|
|
|
$valueSet = true; |
860
|
|
|
$value = $row; |
861
|
|
|
} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) { |
862
|
|
|
$valueSet = true; |
863
|
|
|
$value = $row[ $paramsColumnKey ]; |
864
|
|
|
} |
865
|
|
|
|
866
|
|
|
if ( $valueSet ) { |
867
|
|
|
if ( $keySet ) { |
868
|
|
|
$resultArray[ $key ] = $value; |
869
|
|
|
} else { |
870
|
|
|
$resultArray[] = $value; |
871
|
|
|
} |
872
|
|
|
} |
873
|
|
|
|
874
|
|
|
} |
875
|
|
|
|
876
|
|
|
return $resultArray; |
877
|
|
|
} |
878
|
|
|
|
879
|
|
|
} |
880
|
|
|
|
881
|
|
|
/** |
882
|
|
|
* Determines the receipt visibility status. |
883
|
|
|
* |
884
|
|
|
* @since 1.3.2 |
885
|
|
|
* |
886
|
|
|
* @param string $payment_key |
887
|
|
|
* |
888
|
|
|
* @return bool Whether the receipt is visible or not. |
889
|
|
|
*/ |
890
|
|
|
function give_can_view_receipt( $payment_key = '' ) { |
891
|
|
|
|
892
|
|
|
$return = false; |
893
|
|
|
|
894
|
|
|
if ( empty( $payment_key ) ) { |
895
|
|
|
return $return; |
896
|
|
|
} |
897
|
|
|
|
898
|
|
|
global $give_receipt_args; |
|
|
|
|
899
|
|
|
|
900
|
|
|
$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key ); |
901
|
|
|
|
902
|
|
|
$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] ); |
903
|
|
|
|
904
|
|
|
$payment_meta = give_get_payment_meta( $give_receipt_args['id'] ); |
905
|
|
|
|
906
|
|
|
if ( is_user_logged_in() ) { |
907
|
|
|
if ( $user_id === (int) get_current_user_id() ) { |
908
|
|
|
$return = true; |
909
|
|
|
} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) { |
910
|
|
|
$return = true; |
911
|
|
|
} elseif ( current_user_can( 'view_give_sensitive_data' ) ) { |
912
|
|
|
$return = true; |
913
|
|
|
} |
914
|
|
|
} |
915
|
|
|
|
916
|
|
|
$session = give_get_purchase_session(); |
917
|
|
|
if ( ! empty( $session ) && ! is_user_logged_in() ) { |
918
|
|
|
if ( $session['purchase_key'] === $payment_meta['key'] ) { |
919
|
|
|
$return = true; |
920
|
|
|
} |
921
|
|
|
} |
922
|
|
|
|
923
|
|
|
return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key ); |
924
|
|
|
|
925
|
|
|
} |
926
|
|
|
|
927
|
|
|
/** |
928
|
|
|
* Fallback for cal_days_in_month |
929
|
|
|
* |
930
|
|
|
* Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar |
931
|
|
|
*/ |
932
|
|
|
if ( ! function_exists( 'cal_days_in_month' ) ) { |
933
|
|
|
/** |
934
|
|
|
* cal_days_in_month |
935
|
|
|
* |
936
|
|
|
* @param $calendar |
937
|
|
|
* @param $month |
938
|
|
|
* @param $year |
939
|
|
|
* |
940
|
|
|
* @return bool|string |
941
|
|
|
*/ |
942
|
|
|
function cal_days_in_month( $calendar, $month, $year ) { |
|
|
|
|
943
|
|
|
return date( 't', mktime( 0, 0, 0, $month, 1, $year ) ); |
944
|
|
|
} |
945
|
|
|
} |
946
|
|
|
|
The PSR-1: Basic Coding Standard recommends that a file should either introduce new symbols, that is classes, functions, constants or similar, or have side effects. Side effects are anything that executes logic, like for example printing output, changing ini settings or writing to a file.
The idea behind this recommendation is that merely auto-loading a class should not change the state of an application. It also promotes a cleaner style of programming and makes your code less prone to errors, because the logic is not spread out all over the place.
To learn more about the PSR-1, please see the PHP-FIG site on the PSR-1.