Test Failed
Push — backup/issues/1132 ( b1d18b )
by Ravinder
05:29
created

includes/misc-functions.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

Code
1
<?php
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
26
	$ret = give_is_setting_enabled( give_get_option( 'test_mode' ) );
27
28
	return (bool) apply_filters( 'give_is_test_mode', $ret );
29
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
40
	$currency = give_get_option( 'currency', 'USD' );
41
42
	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
54
	$currency_pos = give_get_option( 'currency_position', 'before' );
55
56
	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
function give_currency_symbol( $currency = '', $decode_currency = false ) {
119
120
	if ( empty( $currency ) ) {
121
		$currency = give_get_currency();
122
	}
123
	switch ( $currency ) :
124
		case 'GBP' :
125
			$symbol = '&pound;';
126
			break;
127
		case 'BRL' :
128
			$symbol = '&#82;&#36;';
129
			break;
130
		case 'EUR' :
131
			$symbol = '&euro;';
132
			break;
133
		case 'NOK' :
134
			$symbol = '&#107;&#114;.';
135
			break;
136
		case 'INR' :
137
			$symbol = '&#8377;';
138
			break;
139
		case 'USD' :
140
		case 'AUD' :
141
		case 'CAD' :
142
		case 'HKD' :
143
		case 'MXN' :
144
		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
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
 * @param string $currency_code
213
 *
214
 * @return string
215
 */
216
function give_get_currency_name( $currency_code ) {
217
	$currency_name  = '';
218
	$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;
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
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
301
		return 'UTC';
302
	}
303
304
	// attempt to guess the timezone string from the UTC offset.
305
	$timezone = timezone_name_from_abbr( '', $utc_offset );
306
307
	// last try, guess timezone string manually.
308
	if ( $timezone === false ) {
309
310
		$is_dst = date( 'I' );
311
312
		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  $name_and_email
391
 * @param int   $length
392
 *
393
 * @return string
394
 */
395
function give_payment_gateway_donation_summary( $donation_data, $name_and_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
	// Add Donor's name + email if requested.
411
	if ( $name_and_email ) {
412
413
		// First name
414 View Code Duplication
		if ( isset( $donation_data['user_info']['first_name'] ) && ! empty( $donation_data['user_info']['first_name'] ) ) {
415
			$summary .= ' - ' . $donation_data['user_info']['first_name'];
416
		}
417
418 View Code Duplication
		if ( isset( $donation_data['user_info']['last_name'] ) && ! empty( $donation_data['user_info']['last_name'] ) ) {
419
			$summary .= ' ' . $donation_data['user_info']['last_name'];
420
		}
421
422
		$summary .= ' (' . $donation_data['user_email'] . ')';
423
	}
424
425
	// Cut the length
426
	$summary = substr( $summary, 0, $length );
427
428
	return apply_filters( 'give_payment_gateway_donation_summary', $summary );
429
}
430
431
432
/**
433
 * Get user host
434
 *
435
 * Returns the webhost this site is using if possible
436
 *
437
 * @since 1.0
438
 * @return string $host if detected, false otherwise
439
 */
440
function give_get_host() {
441
	$host = false;
442
443
	if ( defined( 'WPE_APIKEY' ) ) {
444
		$host = 'WP Engine';
445
	} elseif ( defined( 'PAGELYBIN' ) ) {
446
		$host = 'Pagely';
447
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
448
		$host = 'ICDSoft';
449
	} elseif ( DB_HOST == 'mysqlv5' ) {
450
		$host = 'NetworkSolutions';
451
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
452
		$host = 'iPage';
453
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
454
		$host = 'IPower';
455
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
456
		$host = 'MediaTemple Grid';
457
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
458
		$host = 'pair Networks';
459
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
460
		$host = 'Rackspace Cloud';
461
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
462
		$host = 'SysFix.eu Power Hosting';
463
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
464
		$host = 'Flywheel';
465
	} else {
466
		// Adding a general fallback for data gathering
467
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
468
	}
469
470
	return $host;
471
}
472
473
474
/**
475
 * Check site host
476
 *
477
 * @since 1.0
478
 *
479
 * @param bool /string $host The host to check
480
 *
481
 * @return bool true if host matches, false if not
482
 */
483
function give_is_host( $host = false ) {
484
485
	$return = false;
486
487
	if ( $host ) {
488
		$host = str_replace( ' ', '', strtolower( $host ) );
489
490
		switch ( $host ) {
491
			case 'wpengine':
492
				if ( defined( 'WPE_APIKEY' ) ) {
493
					$return = true;
494
				}
495
				break;
496
			case 'pagely':
497
				if ( defined( 'PAGELYBIN' ) ) {
498
					$return = true;
499
				}
500
				break;
501
			case 'icdsoft':
502
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
503
					$return = true;
504
				}
505
				break;
506
			case 'networksolutions':
507
				if ( DB_HOST == 'mysqlv5' ) {
508
					$return = true;
509
				}
510
				break;
511
			case 'ipage':
512
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
513
					$return = true;
514
				}
515
				break;
516
			case 'ipower':
517
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
518
					$return = true;
519
				}
520
				break;
521
			case 'mediatemplegrid':
522
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
523
					$return = true;
524
				}
525
				break;
526
			case 'pairnetworks':
527
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
528
					$return = true;
529
				}
530
				break;
531
			case 'rackspacecloud':
532
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
533
					$return = true;
534
				}
535
				break;
536
			case 'sysfix.eu':
537
			case 'sysfix.eupowerhosting':
538
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
539
					$return = true;
540
				}
541
				break;
542
			case 'flywheel':
543
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
544
					$return = true;
545
				}
546
				break;
547
			default:
548
				$return = false;
549
		}// End switch().
550
	}// End if().
551
552
	return $return;
553
}
554
555
/**
556
 * Marks a function as deprecated and informs when it has been used.
557
 *
558
 * There is a hook give_deprecated_function_run that will be called that can be used
559
 * to get the backtrace up to what file and function called the deprecated
560
 * function.
561
 *
562
 * The current behavior is to trigger a user error if WP_DEBUG is true.
563
 *
564
 * This function is to be used in every function that is deprecated.
565
 *
566
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
567
 *   and the version the function was deprecated in.
568
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
569
 *   trigger or false to not trigger error.
570
 *
571
 * @param string $function    The function that was called.
572
 * @param string $version     The plugin version that deprecated the function.
573
 * @param string $replacement Optional. The function that should have been called.
574
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
575
 */
576
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
577
578
	/**
579
	 * Fires while give deprecated function call occurs.
580
	 *
581
	 * Allow you to hook to deprecated function call.
582
	 *
583
	 * @since 1.0
584
	 *
585
	 * @param string $function    The function that was called.
586
	 * @param string $replacement Optional. The function that should have been called.
587
	 * @param string $version     The plugin version that deprecated the function.
588
	 */
589
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
590
591
	$show_errors = current_user_can( 'manage_options' );
592
593
	// Allow plugin to filter the output error trigger.
594
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
595
		if ( ! is_null( $replacement ) ) {
596
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
597
			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.
598
			// Alternatively we could dump this to a file.
599
		} else {
600
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
601
			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.
602
			// Alternatively we could dump this to a file.
603
		}
604
	}
605
}
606
607
/**
608
 * Give Get Admin ID
609
 *
610
 * Helper function to return the ID of the post for admin usage
611
 *
612
 * @return string $post_id
613
 */
614
function give_get_admin_post_id() {
615
	$post_id = isset( $_REQUEST['post'] )
616
		? absint( $_REQUEST['post'] )
617
		: null;
618
619
	$post_id = ! empty( $post_id )
620
		? $post_id
621
		: ( isset( $_REQUEST['post_id'] ) ? absint( $_REQUEST['post_id'] ) : null );
622
623
	$post_id = ! empty( $post_id )
624
		? $post_id
625
		: ( isset( $_REQUEST['post_ID'] ) ? absint( $_REQUEST['post_ID'] ) : null );
626
627
	return $post_id;
628
}
629
630
/**
631
 * Get PHP Arg Separator Output
632
 *
633
 * @since 1.0
634
 * @return string Arg separator output
635
 */
636
function give_get_php_arg_separator_output() {
637
	return ini_get( 'arg_separator.output' );
638
}
639
640
641
/**
642
 * Month Num To Name
643
 *
644
 * Takes a month number and returns the name three letter name of it.
645
 *
646
 * @since 1.0
647
 *
648
 * @param int $n
649
 *
650
 * @return string Short month name
651
 */
652
function give_month_num_to_name( $n ) {
653
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
654
655
	return date_i18n( 'M', $timestamp );
656
}
657
658
659
/**
660
 * Checks whether function is disabled.
661
 *
662
 * @since 1.0
663
 *
664
 * @param string $function Name of the function.
665
 *
666
 * @return bool Whether or not function is disabled.
667
 */
668
function give_is_func_disabled( $function ) {
669
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
670
671
	return in_array( $function, $disabled );
672
}
673
674
675
/**
676
 * Give Newsletter
677
 *
678
 * Returns the main Give newsletter form
679
 */
680
function give_get_newsletter() {
681
	?>
682
683
	<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>
684
685
	<div class="give-newsletter-form-wrap">
686
687
		<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13"
688
		      method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate"
689
		      target="_blank" novalidate>
690
			<div class="give-newsletter-confirmation">
691
				<p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
692
			</div>
693
694
			<table class="form-table give-newsletter-form">
695
				<tr valign="middle">
696
					<td>
697
						<label for="mce-EMAIL"
698
						       class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
699
						<input type="email" name="EMAIL" id="mce-EMAIL"
700
						       placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>"
701
						       class="required email" value="">
702
					</td>
703
					<td>
704
						<label for="mce-FNAME"
705
						       class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
706
						<input type="text" name="FNAME" id="mce-FNAME"
707
						       placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
708
					</td>
709
					<td>
710
						<label for="mce-LNAME"
711
						       class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
712
						<input type="text" name="LNAME" id="mce-LNAME"
713
						       placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
714
					</td>
715
					<td>
716
						<input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button"
717
						       value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
718
					</td>
719
				</tr>
720
			</table>
721
		</form>
722
723
		<div style="position: absolute; left: -5000px;">
724
			<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
725
		</div>
726
727
	</div>
728
729
	<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>
730
	<script type='text/javascript'>(function( $ ) {
731
				window.fnames = new Array();
732
				window.ftypes = new Array();
733
				fnames[ 0 ] = 'EMAIL';
734
				ftypes[ 0 ] = 'email';
735
				fnames[ 1 ] = 'FNAME';
736
				ftypes[ 1 ] = 'text';
737
				fnames[ 2 ] = 'LNAME';
738
				ftypes[ 2 ] = 'text';
739
740
				//Successful submission
741
				$( 'form[name="mc-embedded-subscribe-form"]' ).on( 'submit', function() {
742
743
					var email_field = $( this ).find( '#mce-EMAIL' ).val();
744
					if ( ! email_field ) {
745
						return false;
746
					}
747
					$( this ).find( '.give-newsletter-confirmation' ).show().delay( 5000 ).slideUp();
748
					$( this ).find( '.give-newsletter-form' ).hide();
749
750
				} );
751
752
			}( jQuery ));
753
			var $mcj = jQuery.noConflict( true );
754
755
756
	</script>
757
	<!--End mc_embed_signup-->
758
759
<?php }
760
761
762
/**
763
 * Create SVG library function
764
 *
765
 * @param string $icon
766
 *
767
 * @return string
768
 */
769
function give_svg_icons( $icon ) {
770
771
	// Store your SVGs in an associative array
772
	$svgs = array(
773
		'microphone'    => '',
774
		'alert'         => '',
775
		'placemark'     => '',
776
		'give_grey'     => '',
777
		'give_cpt_icon' => '',
778
	);
779
780
	// Return the chosen icon's SVG string
781
	return $svgs[ $icon ];
782
}
783
784
/**
785
 * Modify Admin Nav Menu Label
786
 *
787
 * @since 1.3
788
 *
789
 * @param object $post_type The current object to add a menu items meta box for.
790
 *
791
 * @return mixed
792
 */
793
function modify_nav_menu_meta_box_object( $post_type ) {
794
	if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) {
795
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
796
	}
797
798
	return $post_type;
799
}
800
801
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
802
803
/**
804
 * Enable 'Donation Form' meta enabled by default on Menu page.
805
 *
806
 * @since 1.8.9
807
 */
808
function give_nav_donation_metabox_enabled() {
809
810
	// Return false, if it fails to retrieve hidden meta box list and is not admin.
811
	if ( ( ! $hidden_meta_boxes = get_user_option( 'metaboxhidden_nav-menus' ) ) || ! is_admin() ) {
812
		return false;
813
	}
814
815
	// Return false, In case, we don't find 'Donation Form' in hidden meta box list.
816
	if ( ! in_array( 'add-post-type-give_forms', $hidden_meta_boxes, true ) ) {
817
		return false;
818
	}
819
820
	// Exclude 'Donation Form' value from hidden meta box's list.
821
	$hidden_meta_boxes = array_diff( $hidden_meta_boxes, array( 'add-post-type-give_forms' ) );
822
823
	// Get current user ID.
824
	$user = wp_get_current_user();
825
826
	update_user_option( $user->ID, 'metaboxhidden_nav-menus', $hidden_meta_boxes, true );
827
}
828
829
/**
830
 * Array_column backup usage
831
 *
832
 * This file is part of the array_column library.
833
 *
834
 * @since      : 1.3.0.1
835
 *
836
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
837
 * @license    https://opensource.org/licenses/MIT MIT
838
 */
839
840
if ( ! function_exists( 'array_column' ) ) {
841
	/**
842
	 * Returns the values from a single column of the input array, identified by
843
	 * the $columnKey.
844
	 *
845
	 * Optionally, you may provide an $indexKey to index the values in the returned
846
	 * array by the values from the $indexKey column in the input array.
847
	 *
848
	 * @param array      $input     A multi-dimensional array (record set) from which to pull
849
	 *                              a column of values.
850
	 * @param int|string $columnKey The column of values to return. This value may be the
851
	 *                              integer key of the column you wish to retrieve, or it
852
	 *                              may be the string key name for an associative array.
853
	 * @param mixed      $indexKey  (Optional.) The column to use as the index/keys for
854
	 *                              the returned array. This value may be the integer key
855
	 *                              of the column, or it may be the string key name.
856
	 *
857
	 * @return array
858
	 */
859
	function array_column( $input = null, $columnKey = null, $indexKey = null ) {
860
		// Using func_get_args() in order to check for proper number of
861
		// parameters and trigger errors exactly as the built-in array_column()
862
		// does in PHP 5.5.
863
		$argc   = func_num_args();
864
		$params = func_get_args();
865
866
		if ( $argc < 2 ) {
867
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
868
869
			return null;
870
		}
871
872
		if ( ! is_array( $params[0] ) ) {
873
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
874
875
			return null;
876
		}
877
878 View Code Duplication
		if ( ! is_int( $params[1] )
879
		     && ! is_float( $params[1] )
880
		     && ! is_string( $params[1] )
881
		     && $params[1] !== null
882
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
883
		) {
884
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
885
886
			return false;
887
		}
888
889 View Code Duplication
		if ( isset( $params[2] )
890
		     && ! is_int( $params[2] )
891
		     && ! is_float( $params[2] )
892
		     && ! is_string( $params[2] )
893
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
894
		) {
895
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
896
897
			return false;
898
		}
899
900
		$paramsInput     = $params[0];
901
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
902
903
		$paramsIndexKey = null;
904
		if ( isset( $params[2] ) ) {
905
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
906
				$paramsIndexKey = (int) $params[2];
907
			} else {
908
				$paramsIndexKey = (string) $params[2];
909
			}
910
		}
911
912
		$resultArray = array();
913
914
		foreach ( $paramsInput as $row ) {
915
			$key    = $value = null;
916
			$keySet = $valueSet = false;
917
918
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
919
				$keySet = true;
920
				$key    = (string) $row[ $paramsIndexKey ];
921
			}
922
923
			if ( $paramsColumnKey === null ) {
924
				$valueSet = true;
925
				$value    = $row;
926
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
927
				$valueSet = true;
928
				$value    = $row[ $paramsColumnKey ];
929
			}
930
931
			if ( $valueSet ) {
932
				if ( $keySet ) {
933
					$resultArray[ $key ] = $value;
934
				} else {
935
					$resultArray[] = $value;
936
				}
937
			}
938
		}
939
940
		return $resultArray;
941
	}
942
}// End if().
943
944
/**
945
 * Determines the receipt visibility status.
946
 *
947
 * @since 1.3.2
948
 *
949
 * @param string $payment_key
950
 *
951
 * @return bool Whether the receipt is visible or not.
952
 */
953
function give_can_view_receipt( $payment_key = '' ) {
954
955
	$return = false;
956
957
	if ( empty( $payment_key ) ) {
958
		return $return;
959
	}
960
961
	global $give_receipt_args;
962
963
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
964
965
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
966
967
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
968
969
	if ( is_user_logged_in() ) {
970
		if ( $user_id === (int) get_current_user_id() ) {
971
			$return = true;
972
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
973
			$return = true;
974
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
975
			$return = true;
976
		}
977
	}
978
979
	$session = give_get_purchase_session();
980
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
981
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
982
			$return = true;
983
		}
984
	}
985
986
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
987
988
}
989
990
/**
991
 * Fallback for cal_days_in_month
992
 *
993
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
994
 */
995
if ( ! function_exists( 'cal_days_in_month' ) ) {
996
	/**
997
	 * cal_days_in_month
998
	 *
999
	 * @param int $calendar
1000
	 * @param int $month
1001
	 * @param int $year
1002
	 *
1003
	 * @return bool|string
1004
	 */
1005
	function cal_days_in_month( $calendar, $month, $year ) {
1006
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
1007
	}
1008
}
1009
1010
/**
1011
 * Get plugin info including status, type, and license validation.
1012
 *
1013
 * This is an enhanced version of get_plugins() that returns the status
1014
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
1015
 * and license validation for Give add-ons (`true` or `false`). Does not include
1016
 * MU plugins.
1017
 *
1018
 * @since 1.8.0
1019
 *
1020
 * @return array Plugin info plus status, type, and license validation if
1021
 *               available.
1022
 */
1023
function give_get_plugins() {
1024
	$plugins             = get_plugins();
1025
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
1026
1027
	if ( is_multisite() ) {
1028
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
1029
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
1030
	}
1031
1032
	foreach ( $plugins as $plugin_path => $plugin_data ) {
1033
		// Is plugin active?
1034
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
1035
			$plugins[ $plugin_path ]['Status'] = 'active';
1036
		} else {
1037
			$plugins[ $plugin_path ]['Status'] = 'inactive';
1038
		}
1039
1040
		$dirname = strtolower( dirname( $plugin_path ) );
1041
1042
		// Is plugin a Give add-on by WordImpress?
1043
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
1044
			// Plugin is a Give-addon.
1045
			$plugins[ $plugin_path ]['Type'] = 'add-on';
1046
1047
			// Get license info from database.
1048
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
1049
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
1050
			$license_active = get_option( $db_option );
1051
1052
			// Does a valid license exist?
1053
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
1054
				$plugins[ $plugin_path ]['License'] = true;
1055
			} else {
1056
				$plugins[ $plugin_path ]['License'] = false;
1057
			}
1058
		} else {
1059
			// Plugin is not a Give add-on.
1060
			$plugins[ $plugin_path ]['Type'] = 'other';
1061
		}
1062
	}
1063
1064
	return $plugins;
1065
}
1066
1067
1068
/**
1069
 * Check if terms enabled or not for form.
1070
 *
1071
 * @since 1.8
1072
 *
1073
 * @param $form_id
1074
 *
1075
 * @return bool
1076
 */
1077
function give_is_terms_enabled( $form_id ) {
1078
	$form_option = give_get_meta( $form_id, '_give_terms_option', true );
1079
1080
	if (
1081
		give_is_setting_enabled( $form_option, 'global' )
1082
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1083
	) {
1084
		return true;
1085
1086
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1087
		return true;
1088
1089
	} else {
1090
		return false;
1091
	}
1092
}
1093
1094
1095
/**
1096
 * Delete donation stats cache.
1097
 *
1098
 * @todo  Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key.
1099
 *
1100
 * @since 1.8.7
1101
 *
1102
 * @param string|array $date_range Date for stats.
1103
 *                                 Date value should be in today, yesterday, this_week, last_week, this_month, last_month, this_quarter, last_quarter, this_year, last_year.
1104
 *                                 For date value other, all cache will be removed.
1105
 *
1106
 * @param array        $args
1107
 *
1108
 * @return WP_Error|bool
1109
 */
1110
function give_delete_donation_stats( $date_range = '', $args = array() ) {
1111
	// Delete all cache.
1112
	$status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) );
1113
1114
	/**
1115
	 * Fire the action when donation stats delete.
1116
	 *
1117
	 * @since 1.8.7
1118
	 *
1119
	 * @param string|array $date_range
1120
	 * @param array        $args
1121
	 */
1122
	do_action( 'give_delete_donation_stats', $status, $date_range, $args );
1123
1124
	return $status;
1125
}
1126
1127
/**
1128
 * Check if admin creating new donation form or not.
1129
 *
1130
 * @since 2.0
1131
 * @return bool
1132
 */
1133
function give_is_add_new_form_page() {
1134
	$status = false;
1135
1136
	if ( false !== strpos( $_SERVER['REQUEST_URI'], '/wp-admin/post-new.php?post_type=give_forms' ) ) {
1137
		$status = true;
1138
	}
1139
1140
	return $status;
1141
}
1142
1143
/**
1144
 * Get Form/Payment meta.
1145
 *
1146
 * @since 1.8.8
1147
 *
1148
 * @param int    $id
1149
 * @param string $meta_key
1150
 * @param bool   $single
1151
 * @param bool   $default
1152
 *
1153
 * @return mixed
1154
 */
1155
function give_get_meta( $id, $meta_key = '', $single = false, $default = false ) {
1156
	/**
1157
	 * Filter the meta value
1158
	 *
1159
	 * @since 1.8.8
1160
	 */
1161
	$meta_value = apply_filters(
1162
		'give_get_meta',
1163
		get_post_meta( $id, $meta_key, $single ),
1164
		$id,
1165
		$meta_key,
1166
		$default
1167
	);
1168
1169
	if (
1170
		( empty( $meta_key ) || empty( $meta_value ) )
1171
		&& $default
1172
	) {
1173
		$meta_value = $default;
1174
	}
1175
1176
	return $meta_value;
1177
}
1178
1179
/**
1180
 * Update 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
 * @param string $prev_value
1188
 *
1189
 * @return mixed
1190
 */
1191
function give_update_meta( $id, $meta_key, $meta_value, $prev_value = '' ) {
1192
	$status = update_post_meta( $id, $meta_key, $meta_value, $prev_value );
1193
1194
	/**
1195
	 * Filter the meta value update status
1196
	 *
1197
	 * @since 1.8.8
1198
	 */
1199
	return apply_filters( 'give_update_meta', $status, $id, $meta_key, $meta_value );
1200
}
1201
1202
/**
1203
 * Delete Form/Payment meta.
1204
 *
1205
 * @since 1.8.8
1206
 *
1207
 * @param int    $id
1208
 * @param string $meta_key
1209
 * @param string $meta_value
1210
 *
1211
 * @return mixed
1212
 */
1213
function give_delete_meta( $id, $meta_key, $meta_value = '' ) {
1214
	$status = delete_post_meta( $id, $meta_key, $meta_value );
1215
1216
	/**
1217
	 * Filter the meta value delete status
1218
	 *
1219
	 * @since 1.8.8
1220
	 */
1221
	return apply_filters( 'give_delete_meta', $status, $id, $meta_key, $meta_value );
1222
}
1223
1224
/**
1225
 * Check if the upgrade routine has been run for a specific action
1226
 *
1227
 * @since  1.0
1228
 *
1229
 * @param  string $upgrade_action The upgrade action to check completion for
1230
 *
1231
 * @return bool                   If the action has been added to the completed actions array
1232
 */
1233
function give_has_upgrade_completed( $upgrade_action = '' ) {
1234
1235
	if ( empty( $upgrade_action ) ) {
1236
		return false;
1237
	}
1238
1239
	$completed_upgrades = give_get_completed_upgrades();
1240
1241
	return in_array( $upgrade_action, $completed_upgrades );
1242
1243
}
1244
1245
/**
1246
 * For use when doing 'stepped' upgrade routines, to see if we need to start somewhere in the middle
1247
 *
1248
 * @since 1.8
1249
 *
1250
 * @return mixed   When nothing to resume returns false, otherwise starts the upgrade where it left off
1251
 */
1252
function give_maybe_resume_upgrade() {
1253
	$doing_upgrade = get_option( 'give_doing_upgrade', false );
1254
	if ( empty( $doing_upgrade ) ) {
1255
		return false;
1256
	}
1257
1258
	return $doing_upgrade;
1259
}
1260
1261
/**
1262
 * Adds an upgrade action to the completed upgrades array
1263
 *
1264
 * @since  1.0
1265
 *
1266
 * @param  string $upgrade_action The action to add to the completed upgrades array
1267
 *
1268
 * @return bool                   If the function was successfully added
1269
 */
1270
function give_set_upgrade_complete( $upgrade_action = '' ) {
1271
1272
	if ( empty( $upgrade_action ) ) {
1273
		return false;
1274
	}
1275
1276
	$completed_upgrades   = give_get_completed_upgrades();
1277
	$completed_upgrades[] = $upgrade_action;
1278
1279
	// Remove any blanks, and only show uniques.
1280
	$completed_upgrades = array_unique( array_values( $completed_upgrades ) );
1281
1282
	/**
1283
	 * Fire the action when any upgrade set to complete.
1284
	 *
1285
	 * @since 1.8.12
1286
	 */
1287
	do_action( 'give_set_upgrade_completed', $upgrade_action, $completed_upgrades );
1288
1289
	return update_option( 'give_completed_upgrades', $completed_upgrades );
1290
}
1291
1292
/**
1293
 * Get's the array of completed upgrade actions
1294
 *
1295
 * @since  1.0
1296
 * @return array The array of completed upgrades
1297
 */
1298
function give_get_completed_upgrades() {
1299
	return (array) get_option( 'give_completed_upgrades' );
1300
}
1301
1302
/**
1303
 * Get attribute string
1304
 *
1305
 * @since 2.0
1306
 *
1307
 * @param array $attributes
1308
 *
1309
 * @return string
1310
 */
1311
function give_get_attribute_str( $attributes ) {
1312
	$attribute_str = '';
1313
1314
	if ( empty( $attributes ) ) {
1315
		return $attribute_str;
1316
	}
1317
1318
	foreach ( $attributes as $tag => $value ) {
1319
		$attribute_str .= " {$tag}=\"{$value}\"";
1320
	}
1321
1322
	return trim( $attribute_str );
1323
}
1324
1325
1326
/**
1327
 * In 2.0 we updated table for log, payment and form.
1328
 *
1329
 * Note: internal purpose only.
1330
 *
1331
 * @since 2.0
1332
 * @global wpdb  $wpdb
1333
 *
1334
 * @param string $type Context for table
1335
 *
1336
 * @return null|array
1337
 */
1338
function __give_v20_bc_table_details( $type ) {
1339
	global $wpdb;
1340
	$table = array();
1341
1342
	// Bailout.
1343
	if ( empty( $type ) ) {
1344
		return null;
1345
	}
1346
1347
	switch ( $type ) {
1348
		case 'form':
1349
			$table['name']         = $wpdb->formmeta;
1350
			$table['column']['id'] = 'form_id';
1351
1352
			break;
1353
1354
		case 'payment':
1355
			$table['name']         = $wpdb->paymentmeta;
1356
			$table['column']['id'] = 'payment_id';
1357
	}
1358
1359
	// Backward compatibility.
1360
	if ( ! give_has_upgrade_completed( 'v20_move_metadata_into_new_table' ) ) {
1361
		$table['name']         = $wpdb->postmeta;
1362
		$table['column']['id'] = 'post_id';
1363
	}
1364
1365
1366
	return $table;
1367
}
1368
1369
/**
1370
 * Remove the Give transaction pages from WP search results.
1371
 *
1372
 * @since 1.8.13
1373
 *
1374
 * @param \WP_Query
1375
 *
1376
 */
1377
function give_remove_pages_from_search( $query ) {
1378
1379
	if ( ! $query->is_admin && $query->is_search && $query->is_main_query() ) {
1380
1381
		$transaction_failed = give_get_option( 'failure_page', 0 );
1382
		$success_page       = give_get_option( 'success_page', 0 );
1383
		$args = apply_filters( 'give_remove_pages_from_search', array( $transaction_failed, $success_page ), $query );
1384
1385
		$query->set( 'post__not_in', $args );
1386
	}
1387
0 ignored issues
show
Functions must not contain multiple empty lines in a row; found 2 empty lines
Loading history...
1388
1389
}
1390
1391
add_action( 'pre_get_posts', 'give_remove_pages_from_search', 10, 1 );
1392