Completed
Pull Request — master (#1907)
by
unknown
19:56
created

misc-functions.php ➔ give_payment_gateway_donation_summary()   D

Complexity

Conditions 9
Paths 64

Size

Total Lines 34
Code Lines 15

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 90

Importance

Changes 0
Metric Value
cc 9
eloc 15
nc 64
nop 3
dl 0
loc 34
rs 4.909
c 0
b 0
f 0
ccs 0
cts 15
cp 0
crap 90
1
<?php
0 ignored issues
show
Coding Style Compatibility introduced by
For compatibility and reusability of your code, PSR1 recommends that a file should introduce either new symbols (like classes, functions, etc.) or have side-effects (like outputting something, or including other files), but not both at the same time. The first symbol is defined on line 24 and the first side effect is on line 14.

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.

Loading history...
2
/**
3
 * Misc Functions
4
 *
5
 * @package     Give
6
 * @subpackage  Functions
7
 * @copyright   Copyright (c) 2016, WordImpress
8
 * @license     https://opensource.org/licenses/gpl-license 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 Enabled.
19
 *
20
 * @since 1.0
21
 *
22
 * @return bool $ret True if return mode is enabled, false otherwise
23
 */
24
function give_is_test_mode() {
25 52
26
	$ret = give_is_setting_enabled( give_get_option( 'test_mode' ) );
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'  => __( 'US Dollars ($)', 'give' ),
70
		'EUR'  => __( 'Euros (€)', 'give' ),
71
		'GBP'  => __( 'Pounds Sterling (£)', 'give' ),
72
		'AUD'  => __( 'Australian Dollars ($)', 'give' ),
73
		'BRL'  => __( 'Brazilian Real (R$)', 'give' ),
74
		'CAD'  => __( 'Canadian Dollars ($)', 'give' ),
75
		'CZK'  => __( 'Czech Koruna (Kč)', 'give' ),
76
		'DKK'  => __( 'Danish Krone (kr.)', 'give' ),
77
		'HKD'  => __( 'Hong Kong Dollar ($)', 'give' ),
78
		'HUF'  => __( 'Hungarian Forint (Ft)', 'give' ),
79
		'ILS'  => __( 'Israeli Shekel (₪)', 'give' ),
80
		'JPY'  => __( 'Japanese Yen (¥)', 'give' ),
81
		'MYR'  => __( 'Malaysian Ringgits (RM)', 'give' ),
82
		'MXN'  => __( 'Mexican Peso ($)', 'give' ),
83
		'MAD'  => __( 'Moroccan Dirham (&#x2e;&#x62f;&#x2e;&#x645;)', 'give' ),
84
		'NZD'  => __( 'New Zealand Dollar ($)', 'give' ),
85
		'NOK'  => __( 'Norwegian Krone (Kr.)', 'give' ),
86
		'PHP'  => __( 'Philippine Pesos (₱)', 'give' ),
87
		'PLN'  => __( 'Polish Zloty (zł)', 'give' ),
88
		'SGD'  => __( 'Singapore Dollar ($)', 'give' ),
89
		'KRW'  => __( 'South Korean Won (₩)', 'give' ),
90
		'ZAR'  => __( 'South African Rand (R)', 'give' ),
91
		'SEK'  => __( 'Swedish Krona (kr)', 'give' ),
92
		'CHF'  => __( 'Swiss Franc (CHF)', 'give' ),
93
		'TWD'  => __( 'Taiwan New Dollars (NT$)', 'give' ),
94
		'THB'  => __( 'Thai Baht (฿)', 'give' ),
95
		'INR'  => __( 'Indian Rupee (₹)', 'give' ),
96
		'TRY'  => __( 'Turkish Lira (₺)', 'give' ),
97
		'RIAL' => __( 'Iranian Rial (﷼)', 'give' ),
98
		'RUB'  => __( '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,
109
 * the currency string is returned.
110
 *
111
 * @since      1.0
112
 *
113
 * @param  string $currency        The currency string.
114
 * @param  bool   $decode_currency Option to HTML decode the currency symbol.
115
 *
116
 * @return string           The symbol to use for the currency
117
 */
118 45
function give_currency_symbol( $currency = '', $decode_currency = false ) {
119
120
	if ( empty( $currency ) ) {
121
		$currency = give_get_currency();
122 45
	}
123
	switch ( $currency ) :
124
		case 'GBP' :
125 45
			$symbol = '&pound;';
126
			break;
127
		case 'BRL' :
128 45
			$symbol = '&#82;&#36;';
129
			break;
130
		case 'EUR' :
131 45
			$symbol = '&euro;';
132
			break;
133
		case 'NOK' :
134 45
			$symbol = '&#107;&#114;.';
135
			break;
136
		case 'INR' :
137 45
			$symbol = '&#8377;';
138 45
			break;
139 45
		case 'USD' :
140 45
		case 'AUD' :
141 45
		case 'CAD' :
142 45
		case 'HKD' :
143 45
		case 'MXN' :
144 45
		case 'SGD' :
145
			$symbol = '&#36;';
146
			break;
147
		case 'JPY' :
148
			$symbol = '&yen;';
149
			break;
150
		case 'THB' :
151
			$symbol = '&#3647;';
152
			break;
153
		case 'TRY' :
154
			$symbol = '&#8378;';
155
			break;
156
		case 'TWD' :
157
			$symbol = '&#78;&#84;&#36;';
158
			break;
159
		case 'ILS' :
160
			$symbol = '&#8362;';
161
			break;
162
		case 'RIAL' :
163
			$symbol = '&#xfdfc;';
164
			break;
165
		case 'RUB' :
166
			$symbol = '&#8381;';
167
			break;
168
		case 'DKK' :
169
		case 'SEK' :
170
			$symbol = '&nbsp;kr.&nbsp;';
171
			break;
172
		case 'PLN' :
173
			$symbol = '&#122;&#322;';
174
			break;
175
		case 'PHP' :
176
			$symbol = '&#8369;';
177
			break;
178
		case 'MYR' :
179
			$symbol = '&#82;&#77;';
180
			break;
181
		case 'HUF' :
182
			$symbol = '&#70;&#116;';
183
			break;
184
		case 'CZK' :
185
			$symbol = '&#75;&#269;';
186
			break;
187
		case 'KRW' :
188
			$symbol = '&#8361;';
189
			break;
190
		case 'ZAR' :
191
			$symbol = '&#82;';
192
			break;
193
		case 'MAD' :
194
			$symbol = '&#x2e;&#x62f;&#x2e;&#x645;';
195
			break;
196
		default :
197
			$symbol = $currency;
198
			break;
199
	endswitch;
200 45
201
	$symbol = ( ! $decode_currency ? $symbol : html_entity_decode( $symbol ) );
202
203
	return apply_filters( 'give_currency_symbol', $symbol, $currency );
204
}
205
206
207
/**
208
 * Get currency name.
209
 *
210
 * @since 1.8.8
211
 *
212 6
 * @param string $currency_code
213
 *
214
 * @return string
215 6
 */
216
function give_get_currency_name( $currency_code ) {
217
	$currency_name  = '';
218 6
	$currency_names = give_get_currencies();
219
220
	if ( $currency_code && array_key_exists( $currency_code, $currency_names ) ) {
221
		$currency_name = explode( '(', $currency_names[ $currency_code ] );
222
		$currency_name = trim( current( $currency_name ) );
223
	}
224
225
	return apply_filters( 'give_currency_name', $currency_name, $currency_code );
226
}
227
228
229
/**
230
 * Get the current page URL.
231
 *
232
 * @since 1.0
233
 * @return string $current_url Current page URL.
234
 */
235
function give_get_current_page_url() {
236
237
	global $wp;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
238
239
	if ( get_option( 'permalink_structure' ) ) {
240
		$base = trailingslashit( home_url( $wp->request ) );
241
	} else {
242
		$base = add_query_arg( $wp->query_string, '', trailingslashit( home_url( $wp->request ) ) );
243
		$base = remove_query_arg( array( 'post_type', 'name' ), $base );
244
	}
245
246
	$scheme      = is_ssl() ? 'https' : 'http';
247
	$current_uri = set_url_scheme( $base, $scheme );
248
249
	if ( is_front_page() ) {
250
		$current_uri = home_url( '/' );
251
	}
252
253
	return apply_filters( 'give_get_current_page_url', $current_uri );
254
255
}
256
257
258
/**
259
 * Verify credit card numbers live?
260
 *
261
 * @since 1.0
262
 *
263
 * @return bool $ret True is verify credit cards is live
264
 */
265
function give_is_cc_verify_enabled() {
266
267
	$ret = true;
268
269
	/**
270
	 * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards.
271
	 * Enable if using more than one gateway if they are not both PayPal and manual, again assuming credit card usage.
272
	 */
273
	$gateways = give_get_enabled_payment_gateways();
274
275
	if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) {
276
		$ret = true;
277
	} elseif ( count( $gateways ) == 1 ) {
278
		$ret = false;
279
	} elseif ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) {
280
		$ret = false;
281
	}
282
283
	return (bool) apply_filters( 'give_verify_credit_cards', $ret );
284
}
285
286
/**
287
 * Retrieve timezone.
288
 *
289
 * @since 1.0
290
 * @return string $timezone The timezone ID.
291
 */
292
function give_get_timezone_id() {
293
294
	// if site timezone string exists, return it.
295
	if ( $timezone = get_option( 'timezone_string' ) ) {
296
		return $timezone;
297
	}
298
299
	// get UTC offset, if it isn't set return UTC.
300 52
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
301
		return 'UTC';
302 52
	}
303
304
	// attempt to guess the timezone string from the UTC offset.
305 52
	$timezone = timezone_name_from_abbr( '', $utc_offset );
306
307
	// last try, guess timezone string manually.
308 52
	if ( $timezone === false ) {
309 52
310 52
		$is_dst = date( 'I' );
311
312 52
		foreach ( timezone_abbreviations_list() as $abbr ) {
313
			foreach ( $abbr as $city ) {
314
				if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) {
315
					return $city['timezone_id'];
316
				}
317
			}
318
		}
319
	}
320
321
	// Fallback.
322
	return 'UTC';
323
}
324
325
326
/**
327
 * Get User IP
328
 *
329
 * Returns the IP address of the current visitor
330
 *
331
 * @since 1.0
332
 * @return string $ip User's IP address
333
 */
334
function give_get_ip() {
335
336
	$ip = '127.0.0.1';
337
338
	if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
339
		// check ip from share internet
340
		$ip = $_SERVER['HTTP_CLIENT_IP'];
341
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
342
		// to check ip is pass from proxy
343
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
344
	} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) {
345
		$ip = $_SERVER['REMOTE_ADDR'];
346
	}
347
348
	return apply_filters( 'give_get_ip', $ip );
349
}
350
351
352
/**
353
 * Store Donation Data in Sessions
354
 *
355
 * Used for storing info about donation
356
 *
357
 * @since 1.0
358
 *
359
 * @param $purchase_data
360
 *
361
 * @uses  Give()->session->set()
362
 */
363
function give_set_purchase_session( $purchase_data = array() ) {
364
	Give()->session->set( 'give_purchase', $purchase_data );
365
	Give()->session->set( 'give_email', $purchase_data['user_email'] );
366
}
367
368
/**
369
 * Retrieve Donation Data from Session
370
 *
371
 * Used for retrieving info about donation
372
 * after completing a donation
373
 *
374
 * @since 1.0
375
 * @uses  Give()->session->get()
376
 * @return mixed array | false
377
 */
378
function give_get_purchase_session() {
379
	return Give()->session->get( 'give_purchase' );
380
}
381
382
/**
383
 * Get Donation Summary
384
 *
385
 * Creates a donation summary for payment gateways from the donation data before the payment is created in the database.
386
 *
387
 * @since       1.8.12
388
 *
389
 * @param array $donation_data
390
 * @param bool  $email
391
 * @param int   $length
392
 *
393
 * @return string
394
 */
395
function give_payment_gateway_donation_summary( $donation_data, $email = true, $length = 255 ) {
396
397
	$summary = '';
398
399
	$form_id = isset( $donation_data['post_data']['give-form-id'] ) ? $donation_data['post_data']['give-form-id'] : '';
400
401
	// Form title.
402
	if ( isset( $donation_data['post_data']['give-form-title'] ) ) {
403
		$summary .= $donation_data['post_data']['give-form-title'];
404
	}
405
	// Form multilevel if applicable.
406
	if ( isset( $donation_data['post_data']['give-price-id'] ) ) {
407
		$summary .= ': ' . give_get_price_option_name( $form_id, $donation_data['post_data']['give-price-id'] );
408
	}
409
410
	// First name
411
	if ( isset( $donation_data['user_info']['first_name'] ) && ! empty( $donation_data['user_info']['first_name'] ) ) {
412
		$summary .= ' - ' . $donation_data['user_info']['first_name'];
413
	}
414
415
	if ( isset( $donation_data['user_info']['last_name'] ) && ! empty( $donation_data['user_info']['last_name'] ) ) {
416
		$summary .= ' ' . $donation_data['user_info']['last_name'];
417
	}
418
419
	// Add Donors email if requested.
420
	if ( $email ) {
421
		$summary .= ' (' . $donation_data['user_email'] . ')';
422
	}
423
424
	// Cut the length
425
	$summary = substr( $summary, 0, $length );
426
427
	return apply_filters( 'give_payment_gateway_donation_summary', $summary );
428
}
429
430
431
/**
432
 * Get user host
433
 *
434
 * Returns the webhost this site is using if possible
435
 *
436
 * @since 1.0
437
 * @return string $host if detected, false otherwise
438
 */
439
function give_get_host() {
440
	$host = false;
441
442
	if ( defined( 'WPE_APIKEY' ) ) {
443
		$host = 'WP Engine';
444
	} elseif ( defined( 'PAGELYBIN' ) ) {
445
		$host = 'Pagely';
446
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
447
		$host = 'ICDSoft';
448
	} elseif ( DB_HOST == 'mysqlv5' ) {
449
		$host = 'NetworkSolutions';
450
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
451
		$host = 'iPage';
452
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
453
		$host = 'IPower';
454
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
455
		$host = 'MediaTemple Grid';
456
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
457
		$host = 'pair Networks';
458
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
459
		$host = 'Rackspace Cloud';
460
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
461
		$host = 'SysFix.eu Power Hosting';
462
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
463
		$host = 'Flywheel';
464
	} else {
465
		// Adding a general fallback for data gathering
466
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
467
	}
468
469
	return $host;
470
}
471
472
473
/**
474
 * Check site host
475
 *
476
 * @since 1.0
477
 *
478
 * @param bool /string $host The host to check
479
 *
480
 * @return bool true if host matches, false if not
481
 */
482
function give_is_host( $host = false ) {
483
484
	$return = false;
485
486
	if ( $host ) {
487
		$host = str_replace( ' ', '', strtolower( $host ) );
488
489
		switch ( $host ) {
490
			case 'wpengine':
491
				if ( defined( 'WPE_APIKEY' ) ) {
492
					$return = true;
493
				}
494
				break;
495
			case 'pagely':
496
				if ( defined( 'PAGELYBIN' ) ) {
497
					$return = true;
498
				}
499
				break;
500
			case 'icdsoft':
501
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
502
					$return = true;
503
				}
504
				break;
505
			case 'networksolutions':
506
				if ( DB_HOST == 'mysqlv5' ) {
507
					$return = true;
508
				}
509
				break;
510
			case 'ipage':
511
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
512
					$return = true;
513
				}
514
				break;
515
			case 'ipower':
516 1
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
517
					$return = true;
518 1
				}
519
				break;
520
			case 'mediatemplegrid':
521 1
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
522
					$return = true;
523
				}
524
				break;
525
			case 'pairnetworks':
526
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
527
					$return = true;
528
				}
529
				break;
530
			case 'rackspacecloud':
531
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
532 1
					$return = true;
533
				}
534
				break;
535
			case 'sysfix.eu':
536
			case 'sysfix.eupowerhosting':
537
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
538
					$return = true;
539
				}
540
				break;
541
			case 'flywheel':
542
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
543
					$return = true;
544
				}
545
				break;
546
			default:
547
				$return = false;
548
		}// End switch().
0 ignored issues
show
Unused Code Comprehensibility introduced by
43% of this comment could be valid code. Did you maybe forget this after debugging?

Sometimes obsolete code just ends up commented out instead of removed. In this case it is better to remove the code once you have checked you do not need it.

The code might also have been commented out for debugging purposes. In this case it is vital that someone uncomments it again or your project may behave in very unexpected ways in production.

This check looks for comments that seem to be mostly valid code and reports them.

Loading history...
549
	}// End if().
0 ignored issues
show
Unused Code Comprehensibility introduced by
43% of this comment could be valid code. Did you maybe forget this after debugging?

Sometimes obsolete code just ends up commented out instead of removed. In this case it is better to remove the code once you have checked you do not need it.

The code might also have been commented out for debugging purposes. In this case it is vital that someone uncomments it again or your project may behave in very unexpected ways in production.

This check looks for comments that seem to be mostly valid code and reports them.

Loading history...
550
551
	return $return;
552
}
553
554
/**
555
 * Marks a function as deprecated and informs when it has been used.
556
 *
557
 * There is a hook give_deprecated_function_run that will be called that can be used
558
 * to get the backtrace up to what file and function called the deprecated
559
 * function.
560
 *
561
 * The current behavior is to trigger a user error if WP_DEBUG is true.
562
 *
563
 * This function is to be used in every function that is deprecated.
564
 *
565
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
566
 *   and the version the function was deprecated in.
567
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
568
 *   trigger or false to not trigger error.
569
 *
570
 * @param string $function    The function that was called.
571
 * @param string $version     The plugin version that deprecated the function.
572
 * @param string $replacement Optional. The function that should have been called.
573
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
574
 */
575
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
576
577
	/**
578
	 * Fires while give deprecated function call occurs.
579
	 *
580
	 * Allow you to hook to deprecated function call.
581
	 *
582
	 * @since 1.0
583
	 *
584
	 * @param string $function    The function that was called.
585
	 * @param string $replacement Optional. The function that should have been called.
586
	 * @param string $version     The plugin version that deprecated the function.
587
	 */
588
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
589
590
	$show_errors = current_user_can( 'manage_options' );
591
592
	// Allow plugin to filter the output error trigger.
593
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
594
		if ( ! is_null( $replacement ) ) {
595
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
596
			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.
597
			// Alternatively we could dump this to a file.
598
		} else {
599
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
600
			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.
601
			// Alternatively we could dump this to a file.
602
		}
603
	}
604
}
605
606
/**
607
 * Give Get Admin ID
608
 *
609
 * Helper function to return the ID of the post for admin usage
610
 *
611
 * @return string $post_id
612
 */
613
function give_get_admin_post_id() {
614
	$post_id = isset( $_GET['post'] ) ? $_GET['post'] : null;
615
	if ( ! $post_id && isset( $_POST['post_id'] ) ) {
616
		$post_id = $_POST['post_id'];
617
	}
618
619
	return $post_id;
620
}
621
622
/**
623
 * Get PHP Arg Separator Output
624
 *
625
 * @since 1.0
626
 * @return string Arg separator output
627
 */
628
function give_get_php_arg_separator_output() {
629
	return ini_get( 'arg_separator.output' );
630
}
631
632
633
/**
634
 * Month Num To Name
635
 *
636
 * Takes a month number and returns the name three letter name of it.
637
 *
638
 * @since 1.0
639
 *
640
 * @param int $n
641
 *
642
 * @return string Short month name
643
 */
644
function give_month_num_to_name( $n ) {
645
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
646
647
	return date_i18n( 'M', $timestamp );
648
}
649
650
651
/**
652
 * Checks whether function is disabled.
653
 *
654
 * @since 1.0
655
 *
656
 * @param string $function Name of the function.
657
 *
658
 * @return bool Whether or not function is disabled.
659
 */
660
function give_is_func_disabled( $function ) {
661
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
662
663
	return in_array( $function, $disabled );
664
}
665
666
667
/**
668
 * Give Newsletter
669
 *
670
 * Returns the main Give newsletter form
671
 */
672
function give_get_newsletter() {
673
	?>
674
675
	<p class="newsletter-intro"><?php esc_html_e( 'Be sure to sign up for the Give newsletter below to stay informed of important updates and news.', 'give' ); ?></p>
676
677
	<div class="give-newsletter-form-wrap">
678
679
		<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13"
680
		      method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate"
681
		      target="_blank" novalidate>
682
			<div class="give-newsletter-confirmation">
683
				<p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
684
			</div>
685
686
			<table class="form-table give-newsletter-form">
687
				<tr valign="middle">
688
					<td>
689
						<label for="mce-EMAIL"
690
						       class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
691
						<input type="email" name="EMAIL" id="mce-EMAIL"
692
						       placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>"
693
						       class="required email" value="">
694
					</td>
695
					<td>
696
						<label for="mce-FNAME"
697
						       class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
698
						<input type="text" name="FNAME" id="mce-FNAME"
699
						       placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
700
					</td>
701
					<td>
702
						<label for="mce-LNAME"
703
						       class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
704
						<input type="text" name="LNAME" id="mce-LNAME"
705
						       placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
706
					</td>
707
					<td>
708
						<input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button"
709
						       value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
710
					</td>
711
				</tr>
712
			</table>
713
		</form>
714
715
		<div style="position: absolute; left: -5000px;">
716
			<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
717
		</div>
718
719
	</div>
720
721
	<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>
722
	<script type='text/javascript'>(function( $ ) {
723
				window.fnames = new Array();
724
				window.ftypes = new Array();
725
				fnames[ 0 ] = 'EMAIL';
726
				ftypes[ 0 ] = 'email';
727
				fnames[ 1 ] = 'FNAME';
728
				ftypes[ 1 ] = 'text';
729
				fnames[ 2 ] = 'LNAME';
730
				ftypes[ 2 ] = 'text';
731
732
				//Successful submission
733
				$( 'form[name="mc-embedded-subscribe-form"]' ).on( 'submit', function() {
734
735
					var email_field = $( this ).find( '#mce-EMAIL' ).val();
736
					if ( ! email_field ) {
737
						return false;
738
					}
739
					$( this ).find( '.give-newsletter-confirmation' ).show().delay( 5000 ).slideUp();
740
					$( this ).find( '.give-newsletter-form' ).hide();
741
742
				} );
743
744
			}( jQuery ));
745
			var $mcj = jQuery.noConflict( true );
746
747
748
	</script>
749
	<!--End mc_embed_signup-->
750
751
<?php }
752
753
754
/**
755
 * Create SVG library function
756
 *
757
 * @param string $icon
758
 *
759
 * @return string
760
 */
761
function give_svg_icons( $icon ) {
762
763
	// Store your SVGs in an associative array
764
	$svgs = array(
765
		'microphone'    => '',
766
		'alert'         => '',
767
		'placemark'     => '',
768
		'give_grey'     => '',
769
		'give_cpt_icon' => '',
770
	);
771
772
	// Return the chosen icon's SVG string
773
	return $svgs[ $icon ];
774
}
775
776
/**
777
 * Modify Admin Nav Menu Label
778
 *
779
 * @since 1.3
780
 *
781
 * @param object $post_type The current object to add a menu items meta box for.
782
 *
783
 * @return mixed
784
 */
785
function modify_nav_menu_meta_box_object( $post_type ) {
786
	if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) {
787
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
788
	}
789
790
	return $post_type;
791
}
792
793
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
794
795
/**
796
 * Enable 'Donation Form' meta enabled by default on Menu page.
797
 *
798
 * @since 1.8.9
799
 */
800
function give_nav_donation_metabox_enabled() {
801
802
	// Return false, if it fails to retrieve hidden meta box list and is not admin.
803
	if ( ( ! $hidden_meta_boxes = get_user_option( 'metaboxhidden_nav-menus' ) ) || ! is_admin() ) {
804
		return false;
805
	}
806
807
	// Return false, In case, we don't find 'Donation Form' in hidden meta box list.
808
	if ( ! in_array( 'add-post-type-give_forms', $hidden_meta_boxes, true ) ) {
809
		return false;
810
	}
811
812
	// Exclude 'Donation Form' value from hidden meta box's list.
813
	$hidden_meta_boxes = array_diff( $hidden_meta_boxes, array( 'add-post-type-give_forms' ) );
814
815
	// Get current user ID.
816
	$user = wp_get_current_user();
817
818
	update_user_option( $user->ID, 'metaboxhidden_nav-menus', $hidden_meta_boxes, true );
819
}
820
821
/**
822
 * Array_column backup usage
823
 *
824
 * This file is part of the array_column library.
825
 *
826
 * @since      : 1.3.0.1
827
 *
828
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
829
 * @license    https://opensource.org/licenses/MIT MIT
830
 */
831
832
if ( ! function_exists( 'array_column' ) ) {
833
	/**
834
	 * Returns the values from a single column of the input array, identified by
835
	 * the $columnKey.
836
	 *
837
	 * Optionally, you may provide an $indexKey to index the values in the returned
838
	 * array by the values from the $indexKey column in the input array.
839
	 *
840
	 * @param array      $input     A multi-dimensional array (record set) from which to pull
841
	 *                              a column of values.
842
	 * @param int|string $columnKey The column of values to return. This value may be the
843
	 *                              integer key of the column you wish to retrieve, or it
844
	 *                              may be the string key name for an associative array.
845
	 * @param mixed      $indexKey  (Optional.) The column to use as the index/keys for
846
	 *                              the returned array. This value may be the integer key
847
	 *                              of the column, or it may be the string key name.
848
	 *
849
	 * @return array
0 ignored issues
show
Documentation introduced by
Should the return type not be null|false|array?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
850
	 */
851
	function array_column( $input = null, $columnKey = null, $indexKey = null ) {
0 ignored issues
show
Unused Code introduced by
The parameter $input is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
Unused Code introduced by
The parameter $columnKey is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
Unused Code introduced by
The parameter $indexKey is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
852
		// Using func_get_args() in order to check for proper number of
853
		// parameters and trigger errors exactly as the built-in array_column()
854
		// does in PHP 5.5.
855
		$argc   = func_num_args();
856
		$params = func_get_args();
857
858
		if ( $argc < 2 ) {
859
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
860
861
			return null;
862
		}
863
864
		if ( ! is_array( $params[0] ) ) {
865
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
866
867
			return null;
868
		}
869
870
		if ( ! is_int( $params[1] )
871
		     && ! is_float( $params[1] )
872
		     && ! is_string( $params[1] )
873
		     && $params[1] !== null
874
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
875
		) {
876
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
877
878
			return false;
879
		}
880
881
		if ( isset( $params[2] )
882
		     && ! is_int( $params[2] )
883
		     && ! is_float( $params[2] )
884
		     && ! is_string( $params[2] )
885
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
886
		) {
887
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
888
889
			return false;
890
		}
891
892
		$paramsInput     = $params[0];
893
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
894
895
		$paramsIndexKey = null;
896
		if ( isset( $params[2] ) ) {
897
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
898
				$paramsIndexKey = (int) $params[2];
899
			} else {
900
				$paramsIndexKey = (string) $params[2];
901
			}
902
		}
903
904
		$resultArray = array();
905
906
		foreach ( $paramsInput as $row ) {
907
			$key    = $value = null;
908
			$keySet = $valueSet = false;
909
910
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
911
				$keySet = true;
912
				$key    = (string) $row[ $paramsIndexKey ];
913
			}
914
915
			if ( $paramsColumnKey === null ) {
916
				$valueSet = true;
917
				$value    = $row;
918
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
919
				$valueSet = true;
920
				$value    = $row[ $paramsColumnKey ];
921
			}
922
923
			if ( $valueSet ) {
924
				if ( $keySet ) {
925
					$resultArray[ $key ] = $value;
926
				} else {
927
					$resultArray[] = $value;
928
				}
929
			}
930
		}
931
932
		return $resultArray;
933
	}
934
}// End if().
0 ignored issues
show
Unused Code Comprehensibility introduced by
43% of this comment could be valid code. Did you maybe forget this after debugging?

Sometimes obsolete code just ends up commented out instead of removed. In this case it is better to remove the code once you have checked you do not need it.

The code might also have been commented out for debugging purposes. In this case it is vital that someone uncomments it again or your project may behave in very unexpected ways in production.

This check looks for comments that seem to be mostly valid code and reports them.

Loading history...
935
936
/**
937
 * Determines the receipt visibility status.
938
 *
939
 * @since 1.3.2
940
 *
941
 * @param string $payment_key
942
 *
943
 * @return bool Whether the receipt is visible or not.
944
 */
945
function give_can_view_receipt( $payment_key = '' ) {
946
947
	$return = false;
948
949
	if ( empty( $payment_key ) ) {
950
		return $return;
951
	}
952
953
	global $give_receipt_args;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
954
955
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
956
957
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
958
959
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
960
961
	if ( is_user_logged_in() ) {
962
		if ( $user_id === (int) get_current_user_id() ) {
963
			$return = true;
964
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
965
			$return = true;
966
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
967
			$return = true;
968
		}
969
	}
970
971
	$session = give_get_purchase_session();
972
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
973
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
974
			$return = true;
975
		}
976
	}
977
978
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
979
980
}
981
982
/**
983
 * Fallback for cal_days_in_month
984
 *
985
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
986
 */
987
if ( ! function_exists( 'cal_days_in_month' ) ) {
988
	/**
989
	 * cal_days_in_month
990
	 *
991
	 * @param int $calendar
992
	 * @param int $month
993
	 * @param int $year
994
	 *
995
	 * @return bool|string
996
	 */
997
	function cal_days_in_month( $calendar, $month, $year ) {
0 ignored issues
show
Unused Code introduced by
The parameter $calendar is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
998
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
999
	}
1000
}
1001
1002
/**
1003
 * Get plugin info including status, type, and license validation.
1004
 *
1005
 * This is an enhanced version of get_plugins() that returns the status
1006
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
1007
 * and license validation for Give add-ons (`true` or `false`). Does not include
1008
 * MU plugins.
1009
 *
1010
 * @since 1.8.0
1011
 *
1012
 * @return array Plugin info plus status, type, and license validation if
1013
 *               available.
1014
 */
1015
function give_get_plugins() {
1016
	$plugins             = get_plugins();
1017
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
1018
1019
	if ( is_multisite() ) {
1020
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
1021
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
1022
	}
1023
1024
	foreach ( $plugins as $plugin_path => $plugin_data ) {
1025
		// Is plugin active?
1026
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
1027
			$plugins[ $plugin_path ]['Status'] = 'active';
1028
		} else {
1029
			$plugins[ $plugin_path ]['Status'] = 'inactive';
1030
		}
1031
1032
		$dirname = strtolower( dirname( $plugin_path ) );
1033
1034
		// Is plugin a Give add-on by WordImpress?
1035
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
1036
			// Plugin is a Give-addon.
1037
			$plugins[ $plugin_path ]['Type'] = 'add-on';
1038
1039
			// Get license info from database.
1040
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
1041
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
1042
			$license_active = get_option( $db_option );
1043
1044
			// Does a valid license exist?
1045
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
1046
				$plugins[ $plugin_path ]['License'] = true;
1047
			} else {
1048
				$plugins[ $plugin_path ]['License'] = false;
1049
			}
1050
		} else {
1051
			// Plugin is not a Give add-on.
1052
			$plugins[ $plugin_path ]['Type'] = 'other';
1053
		}
1054
	}
1055
1056
	return $plugins;
1057
}
1058
1059
1060
/**
1061
 * Check if terms enabled or not for form.
1062
 *
1063
 * @since 1.8
1064
 *
1065
 * @param $form_id
1066
 *
1067
 * @return bool
1068
 */
1069
function give_is_terms_enabled( $form_id ) {
1070
	$form_option = give_get_meta( $form_id, '_give_terms_option', true );
1071
1072
	if (
1073
		give_is_setting_enabled( $form_option, 'global' )
1074
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1075
	) {
1076
		return true;
1077
1078
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1079
		return true;
1080
1081
	} else {
1082
		return false;
1083
	}
1084
}
1085
1086
1087
/**
1088
 * Delete donation stats cache.
1089
 *
1090
 * @todo  Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key.
1091
 *
1092
 * @since 1.8.7
1093
 *
1094
 * @param string|array $date_range Date for stats.
1095
 *                                 Date value should be in today, yesterday, this_week, last_week, this_month, last_month, this_quarter, last_quarter, this_year, last_year.
1096
 *                                 For date value other, all cache will be removed.
1097
 *
1098
 * @param array        $args
1099
 *
1100
 * @return WP_Error|bool
1101
 */
1102
function give_delete_donation_stats( $date_range = '', $args = array() ) {
1103
	// Delete all cache.
1104
	$status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) );
1105
1106
	/**
1107
	 * Fire the action when donation stats delete.
1108
	 *
1109
	 * @since 1.8.7
1110
	 *
1111
	 * @param string|array $date_range
1112
	 * @param array        $args
1113
	 */
1114
	do_action( 'give_delete_donation_stats', $status, $date_range, $args );
1115
1116
	return $status;
1117
}
1118
1119
1120
/**
1121
 * Get Form/Payment meta.
1122
 *
1123
 * @since 1.8.8
1124
 *
1125
 * @param int    $id
1126
 * @param string $meta_key
1127
 * @param bool   $single
1128
 * @param bool   $default
1129
 *
1130
 * @return mixed
1131
 */
1132
function give_get_meta( $id, $meta_key, $single = false, $default = false ) {
1133
	/**
1134
	 * Filter the meta value
1135
	 *
1136
	 * @since 1.8.8
1137
	 */
1138
	$meta_value = apply_filters(
1139
		'give_get_meta',
1140
		get_post_meta( $id, $meta_key, $single ),
1141
		$id,
1142
		$meta_key,
1143
		$default
1144
	);
1145
1146
	if (
1147
		( empty( $meta_key ) || empty( $meta_value ) )
1148
		&& $default
1149
	) {
1150
		$meta_value = $default;
1151
	}
1152
1153
	return $meta_value;
1154
}
1155
1156
/**
1157
 * Update Form/Payment meta.
1158
 *
1159
 * @since 1.8.8
1160
 *
1161
 * @param int    $id
1162
 * @param string $meta_key
1163
 * @param string $meta_value
1164
 * @param string $prev_value
1165
 *
1166
 * @return mixed
1167
 */
1168
function give_update_meta( $id, $meta_key, $meta_value, $prev_value = '' ) {
1169
	$status = update_post_meta( $id, $meta_key, $meta_value, $prev_value );
1170
1171
	/**
1172
	 * Filter the meta value update status
1173
	 *
1174
	 * @since 1.8.8
1175
	 */
1176
	return apply_filters( 'give_update_meta', $status, $id, $meta_key, $meta_value );
1177
}
1178
1179
/**
1180
 * Delete Form/Payment meta.
1181
 *
1182
 * @since 1.8.8
1183
 *
1184
 * @param int    $id
1185
 * @param string $meta_key
1186
 * @param string $meta_value
1187
 *
1188
 * @return mixed
1189
 */
1190
function give_delete_meta( $id, $meta_key, $meta_value = '' ) {
1191
	$status = delete_post_meta( $id, $meta_key, $meta_value );
1192
1193
	/**
1194
	 * Filter the meta value delete status
1195
	 *
1196
	 * @since 1.8.8
1197
	 */
1198
	return apply_filters( 'give_delete_meta', $status, $id, $meta_key, $meta_value );
1199
}
1200