Completed
Push — master ( 0af146...0e0d02 )
by Devin
13s
created

misc-functions.php ➔ give_get_plugins()   C

Complexity

Conditions 8
Paths 14

Size

Total Lines 43
Code Lines 24

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 72

Importance

Changes 0
Metric Value
cc 8
eloc 24
nc 14
nop 0
dl 0
loc 43
rs 5.3846
c 0
b 0
f 0
ccs 0
cts 0
cp 0
crap 72
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'  => 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 (&#x2e;&#x62f;&#x2e;&#x645;)', '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 = '&#x2e;&#x62f;&#x2e;&#x645;';
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
		$http_host = sanitize_text_field( $_SERVER['HTTP_HOST'] );
216
		$request_uri = sanitize_text_field( $_SERVER['REQUEST_URI'] );
217
		$current_url = set_url_scheme( 'http://' . $http_host . untrailingslashit( $request_uri ) );
218 6
	}
219
220
	return apply_filters( 'give_get_current_page_url', $current_url );
221
}
222
223
224
/**
225
 * Verify credit card numbers live?
226
 *
227
 * @since 1.0
228
 *
229
 * @return bool $ret True is verify credit cards is live
230
 */
231
function give_is_cc_verify_enabled() {
232
233
	$ret = true;
234
235
	/*
236
	 * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards
237
	 * Enable if using more than one gateway if they aren't both PayPal and manual, again assuming credit card usage
238
	 */
239
	$gateways = give_get_enabled_payment_gateways();
240
241
	if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) {
242
		$ret = true;
243
	} else if ( count( $gateways ) == 1 ) {
244
		$ret = false;
245
	} else if ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) {
246
		$ret = false;
247
	}
248
249
	return (bool) apply_filters( 'give_verify_credit_cards', $ret );
250
}
251
252
/**
253
 * Retrieve timezone
254
 *
255
 * @since 1.0
256
 * @return string $timezone The timezone ID
257
 */
258
function give_get_timezone_id() {
259
260
	// if site timezone string exists, return it
261
	if ( $timezone = get_option( 'timezone_string' ) ) {
262
		return $timezone;
263
	}
264
265
	// get UTC offset, if it isn't set return UTC
266
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
267
		return 'UTC';
268
	}
269
270
	// attempt to guess the timezone string from the UTC offset
271
	$timezone = timezone_name_from_abbr( '', $utc_offset );
272
273
	// last try, guess timezone string manually
274
	if ( $timezone === false ) {
275
276
		$is_dst = date( 'I' );
277
278
		foreach ( timezone_abbreviations_list() as $abbr ) {
279
			foreach ( $abbr as $city ) {
280
				if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) {
281
					return $city['timezone_id'];
282
				}
283
			}
284
		}
285
	}
286
287
	// fallback
288
	return 'UTC';
289
}
290
291
292
/**
293
 * Get User IP
294
 *
295
 * Returns the IP address of the current visitor
296
 *
297
 * @since 1.0
298
 * @return string $ip User's IP address
299
 */
300 52
function give_get_ip() {
301
302 52
	$ip = '127.0.0.1';
303
304
	if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
305 52
		//check ip from share internet
306
		$ip = $_SERVER['HTTP_CLIENT_IP'];
307
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
308 52
		//to check ip is pass from proxy
309 52
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
310 52
	} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) {
311
		$ip = $_SERVER['REMOTE_ADDR'];
312 52
	}
313
314
	return apply_filters( 'give_get_ip', $ip );
315
}
316
317
318
/**
319
 * Store Donation Data in Sessions
320
 *
321
 * Used for storing info about donation
322
 *
323
 * @since 1.0
324
 *
325
 * @param $purchase_data
326
 *
327
 * @uses  Give()->session->set()
328
 */
329
function give_set_purchase_session( $purchase_data = array() ) {
330
	Give()->session->set( 'give_purchase', $purchase_data );
331
	Give()->session->set( 'give_email', $purchase_data['user_email'] );
332
}
333
334
/**
335
 * Retrieve Donation Data from Session
336
 *
337
 * Used for retrieving info about donation
338
 * after completing a donation
339
 *
340
 * @since 1.0
341
 * @uses  Give()->session->get()
342
 * @return mixed array | false
343
 */
344
function give_get_purchase_session() {
345
	return Give()->session->get( 'give_purchase' );
346
}
347
348
/**
349
 * Get Donation Summary
350
 *
351
 * Retrieves the donation summary.
352
 *
353
 * @since       1.0
354
 *
355
 * @param array $purchase_data
356
 * @param bool  $email
357
 *
358
 * @return string
359
 */
360
function give_get_purchase_summary( $purchase_data, $email = true ) {
361
	$summary = '';
362
363
	if ( $email ) {
364
		$summary .= $purchase_data['user_email'] . ' - ';
365
	}
366
367
	$summary .= get_the_title( $purchase_data['post_data']['give-form-id'] );
368
369
	return $summary;
370
}
371
372
373
/**
374
 * Get user host
375
 *
376
 * Returns the webhost this site is using if possible
377
 *
378
 * @since 1.0
379
 * @return string $host if detected, false otherwise
380
 */
381
function give_get_host() {
382
	$host = false;
383
384
	if ( defined( 'WPE_APIKEY' ) ) {
385
		$host = 'WP Engine';
386
	} elseif ( defined( 'PAGELYBIN' ) ) {
387
		$host = 'Pagely';
388
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
389
		$host = 'ICDSoft';
390
	} elseif ( DB_HOST == 'mysqlv5' ) {
391
		$host = 'NetworkSolutions';
392
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
393
		$host = 'iPage';
394
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
395
		$host = 'IPower';
396
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
397
		$host = 'MediaTemple Grid';
398
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
399
		$host = 'pair Networks';
400
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
401
		$host = 'Rackspace Cloud';
402
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
403
		$host = 'SysFix.eu Power Hosting';
404
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
405
		$host = 'Flywheel';
406
	} else {
407
		// Adding a general fallback for data gathering
408
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
409
	}
410
411
	return $host;
412
}
413
414
415
/**
416
 * Check site host
417
 *
418
 * @since 1.0
419
 *
420
 * @param bool /string $host The host to check
421
 *
422
 * @return bool true if host matches, false if not
423
 */
424
function give_is_host( $host = false ) {
425
426
	$return = false;
427
428
	if ( $host ) {
429
		$host = str_replace( ' ', '', strtolower( $host ) );
430
431
		switch ( $host ) {
432
			case 'wpengine':
433
				if ( defined( 'WPE_APIKEY' ) ) {
434
					$return = true;
435
				}
436
				break;
437
			case 'pagely':
438
				if ( defined( 'PAGELYBIN' ) ) {
439
					$return = true;
440
				}
441
				break;
442
			case 'icdsoft':
443
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
444
					$return = true;
445
				}
446
				break;
447
			case 'networksolutions':
448
				if ( DB_HOST == 'mysqlv5' ) {
449
					$return = true;
450
				}
451
				break;
452
			case 'ipage':
453
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
454
					$return = true;
455
				}
456
				break;
457
			case 'ipower':
458
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
459
					$return = true;
460
				}
461
				break;
462
			case 'mediatemplegrid':
463
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
464
					$return = true;
465
				}
466
				break;
467
			case 'pairnetworks':
468
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
469
					$return = true;
470
				}
471
				break;
472
			case 'rackspacecloud':
473
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
474
					$return = true;
475
				}
476
				break;
477
			case 'sysfix.eu':
478
			case 'sysfix.eupowerhosting':
479
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
480
					$return = true;
481
				}
482
				break;
483
			case 'flywheel':
484
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
485
					$return = true;
486
				}
487
				break;
488
			default:
489
				$return = false;
490
		}
491
	}
492
493
	return $return;
494
}
495
496
/**
497
 * Marks a function as deprecated and informs when it has been used.
498
 *
499
 * There is a hook give_deprecated_function_run that will be called that can be used
500
 * to get the backtrace up to what file and function called the deprecated
501
 * function.
502
 *
503
 * The current behavior is to trigger a user error if WP_DEBUG is true.
504
 *
505
 * This function is to be used in every function that is deprecated.
506
 *
507
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
508
 *   and the version the function was deprecated in.
509
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
510
 *   trigger or false to not trigger error.
511
 *
512
 * @param string $function    The function that was called.
513
 * @param string $version     The plugin version that deprecated the function.
514
 * @param string $replacement Optional. The function that should have been called.
515
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
516 1
 */
517
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
518 1
519
	/**
520
	 * Fires while give deprecated function call occurs.
521 1
	 *
522
	 * Allow you to hook to deprecated function call.
523
	 *
524
	 * @since 1.0
525
	 *
526
	 * @param string $function    The function that was called.
527
	 * @param string $replacement Optional. The function that should have been called.
528
	 * @param string $version     The plugin version that deprecated the function.
529
	 */
530
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
531
532 1
	$show_errors = current_user_can( 'manage_options' );
533
534
	// Allow plugin to filter the output error trigger
535
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
536
		if ( ! is_null( $replacement ) ) {
537
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
538
			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.
539
			// Alternatively we could dump this to a file.
540
		} else {
541
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
542
			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.
543
			// Alternatively we could dump this to a file.
544
		}
545
	}
546
}
547
548
/**
549
 * Give Get Admin ID
550
 *
551
 * Helper function to return the ID of the post for admin usage
552
 *
553
 * @return string $post_id
554
 */
555
function give_get_admin_post_id() {
556
	$post_id = isset( $_GET['post'] ) ? $_GET['post'] : null;
557
	if ( ! $post_id && isset( $_POST['post_id'] ) ) {
558
		$post_id = $_POST['post_id'];
559
	}
560
561
	return $post_id;
562
}
563
564
/**
565
 * Get PHP Arg Separator Output
566
 *
567
 * @since 1.0
568
 * @return string Arg separator output
569
 */
570
function give_get_php_arg_separator_output() {
571
	return ini_get( 'arg_separator.output' );
572
}
573
574
575
/**
576
 * Month Num To Name
577
 *
578
 * Takes a month number and returns the name three letter name of it.
579
 *
580
 * @since 1.0
581
 *
582
 * @param int $n
583
 *
584
 * @return string Short month name
585
 */
586
function give_month_num_to_name( $n ) {
587
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
588
589
	return date_i18n( "M", $timestamp );
590
}
591
592
593
/**
594
 * Checks whether function is disabled.
595
 *
596
 * @since 1.0
597
 *
598
 * @param string $function Name of the function.
599
 *
600
 * @return bool Whether or not function is disabled.
601
 */
602
function give_is_func_disabled( $function ) {
603
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
604
605
	return in_array( $function, $disabled );
606
}
607
608
609
/**
610
 * Give Newsletter
611
 *
612
 * Returns the main Give newsletter form
613
 */
614
function give_get_newsletter() { ?>
615
616
	<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>
617
618
	<div class="give-newsletter-form-wrap">
619
620
		<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13" method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate" target="_blank" novalidate>
621
			<div class="give-newsletter-confirmation">
622
				<p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
623
			</div>
624
625
			<table class="form-table give-newsletter-form">
626
				<tr valign="middle">
627
					<td>
628
						<label for="mce-EMAIL" class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
629
						<input type="email" name="EMAIL" id="mce-EMAIL" placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>" class="required email" value="">
630
					</td>
631
					<td>
632
						<label for="mce-FNAME" class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
633
						<input type="text" name="FNAME" id="mce-FNAME" placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
634
					</td>
635
					<td>
636
						<label for="mce-LNAME" class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
637
						<input type="text" name="LNAME" id="mce-LNAME" placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
638
					</td>
639
					<td>
640
						<input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button" value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
641
					</td>
642
				</tr>
643
			</table>
644
		</form>
645
646
		<div style="position: absolute; left: -5000px;">
647
			<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
648
		</div>
649
650
	</div>
651
652
	<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>
653
	<script type='text/javascript'>(function ($) {
654
			window.fnames = new Array();
655
			window.ftypes = new Array();
656
			fnames[0] = 'EMAIL';
657
			ftypes[0] = 'email';
658
			fnames[1] = 'FNAME';
659
			ftypes[1] = 'text';
660
			fnames[2] = 'LNAME';
661
			ftypes[2] = 'text';
662
663
			//Successful submission
664
			$('form[name="mc-embedded-subscribe-form"]').on('submit', function () {
665
666
				var email_field = $(this).find('#mce-EMAIL').val();
667
				if (!email_field) {
668
					return false;
669
				}
670
				$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp();
671
				$(this).find('.give-newsletter-form').hide();
672
673
			});
674
675
676
		}(jQuery));
677
		var $mcj = jQuery.noConflict(true);
678
679
680
	</script>
681
	<!--End mc_embed_signup-->
682
683
<?php }
684
685
686
/**
687
 * Social Media Like Buttons
688
 *
689
 * Various social media elements to Give
690
 */
691
function give_social_media_elements() {
692
?>
693
694
	<div class="social-items-wrap">
695
696
		<iframe src="//www.facebook.com/plugins/like.php?href=https%3A%2F%2Fwww.facebook.com%2Fwpgive&amp;send=false&amp;layout=button_count&amp;width=100&amp;show_faces=false&amp;font&amp;colorscheme=light&amp;action=like&amp;height=21&amp;appId=220596284639969" scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:100px; height:21px;" allowTransparency="true"></iframe>
697
698
		<a href="https://twitter.com/givewp" class="twitter-follow-button" data-show-count="false"><?php
699
			printf(
700
				/* translators: %s: Give twitter user @givewp */
701
				esc_html_e( 'Follow %s', 'give' ),
702
				'@givewp'
703
			);
704
		?></a>
705
		<script>!function (d, s, id) {
706
				var js, fjs = d.getElementsByTagName(s)[0], p = /^http:/.test(d.location) ? 'http' : 'https';
707
				if (!d.getElementById(id)) {
708
					js = d.createElement(s);
709
					js.id = id;
710
					js.src = p + '://platform.twitter.com/widgets.js';
711
					fjs.parentNode.insertBefore(js, fjs);
712
				}
713
			}(document, 'script', 'twitter-wjs');
714
		</script>
715
716
	</div>
717
	<!--/.social-items-wrap -->
718
719
<?php
720
}
721
722
723
/**
724
 * Create SVG library function
725
 *
726
 * @param string $icon
727
 *
728
 * @return string
729
 */
730
function give_svg_icons( $icon ) {
731
732
	// Store your SVGs in an associative array
733
	$svgs = array(
734
		'microphone'    => '',
735
		'alert'         => "",
736
		'placemark'     => '',
737
		'give_grey'     => '',
738
		'give_cpt_icon' => '',
739
	);
740
741
	// Return the chosen icon's SVG string
742
	return $svgs[ $icon ];
743
}
744
745
/**
746
 * Modify Admin Nav Menu Label
747
 *
748
 * @since 1.3
749
 *
750
 * @param object $post_type The current object to add a menu items meta box for.
751
 *
752
 * @return mixed
753
 */
754
function modify_nav_menu_meta_box_object( $post_type ) {
755
	if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) {
756
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
757
	}
758
759
	return $post_type;
760
}
761
762
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
763
764
765
/**
766
 * Array_column backup usage
767
 *
768
 * This file is part of the array_column library.
769
 *
770
 * @since      : 1.3.0.1
771
 *
772
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
773
 * @license    https://opensource.org/licenses/MIT MIT
774
 */
775
776
if ( ! function_exists( 'array_column' ) ) {
777
	/**
778
	 * Returns the values from a single column of the input array, identified by
779
	 * the $columnKey.
780
	 *
781
	 * Optionally, you may provide an $indexKey to index the values in the returned
782
	 * array by the values from the $indexKey column in the input array.
783
	 *
784
	 * @param array $input A multi-dimensional array (record set) from which to pull
785
	 *                         a column of values.
786
	 * @param int|string $columnKey The column of values to return. This value may be the
787
	 *                         integer key of the column you wish to retrieve, or it
788
	 *                         may be the string key name for an associative array.
789
	 * @param mixed $indexKey (Optional.) The column to use as the index/keys for
790
	 *                         the returned array. This value may be the integer key
791
	 *                         of the column, or it may be the string key name.
792
	 *
793
	 * @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...
794
	 */
795
	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...
796
		// Using func_get_args() in order to check for proper number of
797
		// parameters and trigger errors exactly as the built-in array_column()
798
		// does in PHP 5.5.
799
		$argc   = func_num_args();
800
		$params = func_get_args();
801
802
		if ( $argc < 2 ) {
803
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
804
805
			return null;
806
		}
807
808
		if ( ! is_array( $params[0] ) ) {
809
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
810
811
			return null;
812
		}
813
814
		if ( ! is_int( $params[1] )
815
		     && ! is_float( $params[1] )
816
		     && ! is_string( $params[1] )
817
		     && $params[1] !== null
818
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
819
		) {
820
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
821
822
			return false;
823
		}
824
825
		if ( isset( $params[2] )
826
		     && ! is_int( $params[2] )
827
		     && ! is_float( $params[2] )
828
		     && ! is_string( $params[2] )
829
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
830
		) {
831
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
832
833
			return false;
834
		}
835
836
		$paramsInput     = $params[0];
837
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
838
839
		$paramsIndexKey = null;
840
		if ( isset( $params[2] ) ) {
841
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
842
				$paramsIndexKey = (int) $params[2];
843
			} else {
844
				$paramsIndexKey = (string) $params[2];
845
			}
846
		}
847
848
		$resultArray = array();
849
850
		foreach ( $paramsInput as $row ) {
851
			$key    = $value = null;
852
			$keySet = $valueSet = false;
853
854
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
855
				$keySet = true;
856
				$key    = (string) $row[ $paramsIndexKey ];
857
			}
858
859
			if ( $paramsColumnKey === null ) {
860
				$valueSet = true;
861
				$value    = $row;
862
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
863
				$valueSet = true;
864
				$value    = $row[ $paramsColumnKey ];
865
			}
866
867
			if ( $valueSet ) {
868
				if ( $keySet ) {
869
					$resultArray[ $key ] = $value;
870
				} else {
871
					$resultArray[] = $value;
872
				}
873
			}
874
875
		}
876
877
		return $resultArray;
878
	}
879
880
}
881
882
/**
883
 * Determines the receipt visibility status.
884
 *
885
 * @since 1.3.2
886
 *
887
 * @param string $payment_key
888
 *
889
 * @return bool Whether the receipt is visible or not.
890
 */
891
function give_can_view_receipt( $payment_key = '' ) {
892
893
	$return = false;
894
895
	if ( empty( $payment_key ) ) {
896
		return $return;
897
	}
898
899
	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...
900
901
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
902
903
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
904
905
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
906
907
	if ( is_user_logged_in() ) {
908
		if ( $user_id === (int) get_current_user_id() ) {
909
			$return = true;
910
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
911
			$return = true;
912
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
913
			$return = true;
914
		}
915
	}
916
917
	$session = give_get_purchase_session();
918
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
919
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
920
			$return = true;
921
		}
922
	}
923
924
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
925
926
}
927
928
/**
929
 * Fallback for cal_days_in_month
930
 *
931
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
932
 */
933
if ( ! function_exists( 'cal_days_in_month' ) ) {
934
	/**
935
	 * cal_days_in_month
936
	 *
937
	 * @param int $calendar
938
	 * @param int $month
939
	 * @param int $year
940
	 *
941
	 * @return bool|string
942
	 */
943
	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...
944
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
945
	}
946
}
947
948
/**
949
 * Get plugin info including status, type, and license validation.
950
 *
951
 * This is an enhanced version of get_plugins() that returns the status
952
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
953
 * and license validation for Give add-ons (`true` or `false`). Does not include
954
 * MU plugins.
955
 *
956
 * @since 1.8.0
957
 *
958
 * @return array Plugin info plus status, type, and license validation if
959
 *               available.
960
 */
961
function give_get_plugins() {
962
	$plugins             = get_plugins();
963
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
964
965
	if ( is_multisite() ) {
966
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
967
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
968
	}
969
970
	foreach ( $plugins as $plugin_path => $plugin_data ) {
971
		// Is plugin active?
972
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
973
			$plugins[ $plugin_path ]['Status'] = 'active';
974
		} else {
975
			$plugins[ $plugin_path ]['Status'] = 'inactive';
976
		}
977
978
		$dirname = strtolower( dirname( $plugin_path ) );
979
980
		// Is plugin a Give add-on by WordImpress?
981
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
982
			// Plugin is a Give-addon.
983
			$plugins[ $plugin_path ]['Type'] = 'add-on';
984
985
			// Get license info from database.
986
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
987
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
988
			$license_active = get_option( $db_option );
989
990
			// Does a valid license exist?
991
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
992
				$plugins[ $plugin_path ]['License'] = true;
993
			} else {
994
				$plugins[ $plugin_path ]['License'] = false;
995
			}
996
		} else {
997
			// Plugin is not a Give add-on.
998
			$plugins[ $plugin_path ]['Type'] = 'other';
999
		}
1000
	}
1001
1002
	return $plugins;
1003
}
1004
1005
1006
/**
1007
 * Check if terms enabled or not for form.
1008
 *
1009
 * @since 1.8
1010
 *
1011
 * @param $form_id
1012
 *
1013
 * @return bool
1014
 */
1015
function give_is_terms_enabled( $form_id ) {
1016
	$form_option = get_post_meta( $form_id, '_give_terms_option', true );
1017
1018
	if (
1019
		give_is_setting_enabled( $form_option, 'global' )
1020
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1021
	) {
1022
		return true;
1023
1024
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1025
		return true;
1026
1027
	} else {
1028
		return false;
1029
	}
1030
}
1031