Completed
Push — release/2.0 ( 9c875b...4d845f )
by Ravinder
19:03
created

misc-functions.php ➔ give_get_admin_post_id()   B

Complexity

Conditions 6
Paths 32

Size

Total Lines 15
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 6
eloc 11
nc 32
nop 0
dl 0
loc 15
rs 8.8571
c 0
b 0
f 0
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
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
 *
115
 * @return string           The symbol to use for the currency
116
 */
117
function give_currency_symbol( $currency = '' ) {
118
119
	if ( empty( $currency ) ) {
120
		$currency = give_get_currency();
121
	}
122
	switch ( $currency ) :
123
		case 'GBP' :
124
			$symbol = '£';
125
			break;
126
		case 'BRL' :
127
			$symbol = 'R$';
128
			break;
129
		case 'EUR' :
130
			$symbol = '€';
131
			break;
132
		case 'NOK' :
133
			$symbol = 'Kr.';
134
			break;
135
		case 'INR' :
136
			$symbol = '₹';
137
			break;
138
		case 'USD' :
139
		case 'AUD' :
140
		case 'CAD' :
141
		case 'HKD' :
142
		case 'MXN' :
143
		case 'SGD' :
144
			$symbol = '$';
145
			break;
146
		case 'JPY' :
147
			$symbol = '¥';
148
			break;
149
		case 'THB' :
150
			$symbol = '฿';
151
			break;
152
		case 'TRY' :
153
			$symbol = '₺';
154
			break;
155
		case 'TWD' :
156
			$symbol = 'NT$';
157
			break;
158
		case 'ILS' :
159
			$symbol = '₪';
160
			break;
161
		case 'RIAL' :
162
			$symbol = '﷼';
163
			break;
164
		case 'RUB' :
165
			$symbol = 'руб';
166
			break;
167
		case 'DKK' :
168
		case 'SEK' :
169
			$symbol = '&nbsp;kr.&nbsp;';
170
			break;
171
		case 'PLN' :
172
			$symbol = 'zł';
173
			break;
174
		case 'PHP' :
175
			$symbol = '₱';
176
			break;
177
		case 'MYR' :
178
			$symbol = 'RM';
179
			break;
180
		case 'HUF' :
181
			$symbol = 'Ft';
182
			break;
183
		case 'CZK' :
184
			$symbol = 'Kč';
185
			break;
186
		case 'KRW' :
187
			$symbol = '₩';
188
			break;
189
		case 'ZAR' :
190
			$symbol = 'R';
191
			break;
192
		case 'MAD' :
193
			$symbol = '&#x2e;&#x62f;&#x2e;&#x645;';
194
			break;
195
		default :
196
			$symbol = $currency;
197
			break;
198
	endswitch;
199
200
201
	return apply_filters( 'give_currency_symbol', $symbol, $currency );
202
}
203
204
205
/**
206
 * Get currency name.
207
 *
208
 * @since 1.8.8
209
 *
210
 * @param string $currency_code
211
 *
212
 * @return string
213
 */
214
function give_get_currency_name( $currency_code ) {
215
	$currency_name = '';
216
	$currency_names = give_get_currencies();
217
218
	if( $currency_code && array_key_exists( $currency_code, $currency_names ) ) {
219
		$currency_name = explode( '(',  $currency_names[$currency_code] );
220
		$currency_name = trim( current( $currency_name ) );
221
	}
222
223
	return apply_filters( 'give_currency_name', $currency_name, $currency_code );
224
}
225
226
227
/**
228
 * Get the current page URL
229
 *
230
 * @since 1.0
231
 * @return string $current_url Current page URL
232
 */
233
function give_get_current_page_url() {
234
235
	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...
236
237
	if ( get_option( 'permalink_structure' ) ) {
238
		$base = trailingslashit( home_url( $wp->request ) );
239
	} else {
240
		$base = add_query_arg( $wp->query_string, '', trailingslashit( home_url( $wp->request ) ) );
241
		$base = remove_query_arg( array( 'post_type', 'name' ), $base );
242
	}
243
244
	$scheme      = is_ssl() ? 'https' : 'http';
245
	$current_uri = set_url_scheme( $base, $scheme );
246
247
	if ( is_front_page() ) {
248
		$current_uri = home_url( '/' );
249
	}
250
251
	return apply_filters( 'give_get_current_page_url', $current_uri );
252
253
}
254
255
256
/**
257
 * Verify credit card numbers live?
258
 *
259
 * @since 1.0
260
 *
261
 * @return bool $ret True is verify credit cards is live
262
 */
263
function give_is_cc_verify_enabled() {
264
265
	$ret = true;
266
267
	/*
268
	 * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards
269
	 * Enable if using more than one gateway if they aren't both PayPal and manual, again assuming credit card usage
270
	 */
271
	$gateways = give_get_enabled_payment_gateways();
272
273
	if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) {
274
		$ret = true;
275
	} else if ( count( $gateways ) == 1 ) {
276
		$ret = false;
277
	} else if ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) {
278
		$ret = false;
279
	}
280
281
	return (bool) apply_filters( 'give_verify_credit_cards', $ret );
282
}
283
284
/**
285
 * Retrieve timezone
286
 *
287
 * @since 1.0
288
 * @return string $timezone The timezone ID
289
 */
290
function give_get_timezone_id() {
291
292
	// if site timezone string exists, return it
293
	if ( $timezone = get_option( 'timezone_string' ) ) {
294
		return $timezone;
295
	}
296
297
	// get UTC offset, if it isn't set return UTC
298
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
299
		return 'UTC';
300
	}
301
302
	// attempt to guess the timezone string from the UTC offset
303
	$timezone = timezone_name_from_abbr( '', $utc_offset );
304
305
	// last try, guess timezone string manually
306
	if ( $timezone === false ) {
307
308
		$is_dst = date( 'I' );
309
310
		foreach ( timezone_abbreviations_list() as $abbr ) {
311
			foreach ( $abbr as $city ) {
312
				if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) {
313
					return $city['timezone_id'];
314
				}
315
			}
316
		}
317
	}
318
319
	// fallback
320
	return 'UTC';
321
}
322
323
324
/**
325
 * Get User IP
326
 *
327
 * Returns the IP address of the current visitor
328
 *
329
 * @since 1.0
330
 * @return string $ip User's IP address
331
 */
332
function give_get_ip() {
333
334
	$ip = '127.0.0.1';
335
336
	if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
337
		//check ip from share internet
338
		$ip = $_SERVER['HTTP_CLIENT_IP'];
339
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
340
		//to check ip is pass from proxy
341
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
342
	} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) {
343
		$ip = $_SERVER['REMOTE_ADDR'];
344
	}
345
346
	return apply_filters( 'give_get_ip', $ip );
347
}
348
349
350
/**
351
 * Store Donation Data in Sessions
352
 *
353
 * Used for storing info about donation
354
 *
355
 * @since 1.0
356
 *
357
 * @param $purchase_data
358
 *
359
 * @uses  Give()->session->set()
360
 */
361
function give_set_purchase_session( $purchase_data = array() ) {
362
	Give()->session->set( 'give_purchase', $purchase_data );
363
	Give()->session->set( 'give_email', $purchase_data['user_email'] );
364
}
365
366
/**
367
 * Retrieve Donation Data from Session
368
 *
369
 * Used for retrieving info about donation
370
 * after completing a donation
371
 *
372
 * @since 1.0
373
 * @uses  Give()->session->get()
374
 * @return mixed array | false
375
 */
376
function give_get_purchase_session() {
377
	return Give()->session->get( 'give_purchase' );
378
}
379
380
/**
381
 * Get Donation Summary
382
 *
383
 * Retrieves the donation summary.
384
 *
385
 * @since       1.0
386
 *
387
 * @param array $purchase_data
388
 * @param bool  $email
389
 *
390
 * @return string
391
 */
392
function give_get_purchase_summary( $purchase_data, $email = true ) {
393
	$summary = '';
394
395
	if ( $email ) {
396
		$summary .= $purchase_data['user_email'] . ' - ';
397
	}
398
399
	$summary .= get_the_title( $purchase_data['post_data']['give-form-id'] );
400
401
	return $summary;
402
}
403
404
405
/**
406
 * Get user host
407
 *
408
 * Returns the webhost this site is using if possible
409
 *
410
 * @since 1.0
411
 * @return string $host if detected, false otherwise
412
 */
413
function give_get_host() {
414
	$host = false;
415
416
	if ( defined( 'WPE_APIKEY' ) ) {
417
		$host = 'WP Engine';
418
	} elseif ( defined( 'PAGELYBIN' ) ) {
419
		$host = 'Pagely';
420
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
421
		$host = 'ICDSoft';
422
	} elseif ( DB_HOST == 'mysqlv5' ) {
423
		$host = 'NetworkSolutions';
424
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
425
		$host = 'iPage';
426
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
427
		$host = 'IPower';
428
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
429
		$host = 'MediaTemple Grid';
430
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
431
		$host = 'pair Networks';
432
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
433
		$host = 'Rackspace Cloud';
434
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
435
		$host = 'SysFix.eu Power Hosting';
436
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
437
		$host = 'Flywheel';
438
	} else {
439
		// Adding a general fallback for data gathering
440
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
441
	}
442
443
	return $host;
444
}
445
446
447
/**
448
 * Check site host
449
 *
450
 * @since 1.0
451
 *
452
 * @param bool /string $host The host to check
453
 *
454
 * @return bool true if host matches, false if not
455
 */
456
function give_is_host( $host = false ) {
457
458
	$return = false;
459
460
	if ( $host ) {
461
		$host = str_replace( ' ', '', strtolower( $host ) );
462
463
		switch ( $host ) {
464
			case 'wpengine':
465
				if ( defined( 'WPE_APIKEY' ) ) {
466
					$return = true;
467
				}
468
				break;
469
			case 'pagely':
470
				if ( defined( 'PAGELYBIN' ) ) {
471
					$return = true;
472
				}
473
				break;
474
			case 'icdsoft':
475
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
476
					$return = true;
477
				}
478
				break;
479
			case 'networksolutions':
480
				if ( DB_HOST == 'mysqlv5' ) {
481
					$return = true;
482
				}
483
				break;
484
			case 'ipage':
485
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
486
					$return = true;
487
				}
488
				break;
489
			case 'ipower':
490
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
491
					$return = true;
492
				}
493
				break;
494
			case 'mediatemplegrid':
495
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
496
					$return = true;
497
				}
498
				break;
499
			case 'pairnetworks':
500
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
501
					$return = true;
502
				}
503
				break;
504
			case 'rackspacecloud':
505
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
506
					$return = true;
507
				}
508
				break;
509
			case 'sysfix.eu':
510
			case 'sysfix.eupowerhosting':
511
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
512
					$return = true;
513
				}
514
				break;
515
			case 'flywheel':
516
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
517
					$return = true;
518
				}
519
				break;
520
			default:
521
				$return = false;
522
		}
523
	}
524
525
	return $return;
526
}
527
528
/**
529
 * Marks a function as deprecated and informs when it has been used.
530
 *
531
 * There is a hook give_deprecated_function_run that will be called that can be used
532
 * to get the backtrace up to what file and function called the deprecated
533
 * function.
534
 *
535
 * The current behavior is to trigger a user error if WP_DEBUG is true.
536
 *
537
 * This function is to be used in every function that is deprecated.
538
 *
539
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
540
 *   and the version the function was deprecated in.
541
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
542
 *   trigger or false to not trigger error.
543
 *
544
 * @param string $function    The function that was called.
545
 * @param string $version     The plugin version that deprecated the function.
546
 * @param string $replacement Optional. The function that should have been called.
547
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
548
 */
549
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
550
551
	/**
552
	 * Fires while give deprecated function call occurs.
553
	 *
554
	 * Allow you to hook to deprecated function call.
555
	 *
556
	 * @since 1.0
557
	 *
558
	 * @param string $function    The function that was called.
559
	 * @param string $replacement Optional. The function that should have been called.
560
	 * @param string $version     The plugin version that deprecated the function.
561
	 */
562
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
563
564
	$show_errors = current_user_can( 'manage_options' );
565
566
	// Allow plugin to filter the output error trigger
567
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
568
		if ( ! is_null( $replacement ) ) {
569
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
570
			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.
571
			// Alternatively we could dump this to a file.
572
		} else {
573
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
574
			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.
575
			// Alternatively we could dump this to a file.
576
		}
577
	}
578
}
579
580
/**
581
 * Give Get Admin ID
582
 *
583
 * Helper function to return the ID of the post for admin usage
584
 *
585
 * @return string $post_id
586
 */
587
function give_get_admin_post_id() {
588
	$post_id = isset( $_REQUEST['post'] )
589
		? absint( $_REQUEST['post'] )
590
		: null;
591
592
	$post_id = ! empty( $post_id )
593
		? $post_id
594
		: ( isset( $_REQUEST['post_id'] ) ? absint( $_REQUEST['post_id'] ) : null );
595
596
	$post_id = ! empty( $post_id )
597
		? $post_id
598
		: ( isset( $_REQUEST['post_ID'] ) ? absint( $_REQUEST['post_ID'] ) : null );
599
600
	return $post_id;
601
}
602
603
/**
604
 * Get PHP Arg Separator Output
605
 *
606
 * @since 1.0
607
 * @return string Arg separator output
608
 */
609
function give_get_php_arg_separator_output() {
610
	return ini_get( 'arg_separator.output' );
611
}
612
613
614
/**
615
 * Month Num To Name
616
 *
617
 * Takes a month number and returns the name three letter name of it.
618
 *
619
 * @since 1.0
620
 *
621
 * @param int $n
622
 *
623
 * @return string Short month name
624
 */
625
function give_month_num_to_name( $n ) {
626
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
627
628
	return date_i18n( "M", $timestamp );
629
}
630
631
632
/**
633
 * Checks whether function is disabled.
634
 *
635
 * @since 1.0
636
 *
637
 * @param string $function Name of the function.
638
 *
639
 * @return bool Whether or not function is disabled.
640
 */
641
function give_is_func_disabled( $function ) {
642
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
643
644
	return in_array( $function, $disabled );
645
}
646
647
648
/**
649
 * Give Newsletter
650
 *
651
 * Returns the main Give newsletter form
652
 */
653
function give_get_newsletter() { ?>
654
655
    <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>
656
657
    <div class="give-newsletter-form-wrap">
658
659
        <form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13"
660
              method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate"
661
              target="_blank" novalidate>
662
            <div class="give-newsletter-confirmation">
663
                <p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
664
            </div>
665
666
            <table class="form-table give-newsletter-form">
667
                <tr valign="middle">
668
                    <td>
669
                        <label for="mce-EMAIL"
670
                               class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
671
                        <input type="email" name="EMAIL" id="mce-EMAIL"
672
                               placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>"
673
                               class="required email" value="">
674
                    </td>
675
                    <td>
676
                        <label for="mce-FNAME"
677
                               class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
678
                        <input type="text" name="FNAME" id="mce-FNAME"
679
                               placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
680
                    </td>
681
                    <td>
682
                        <label for="mce-LNAME"
683
                               class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
684
                        <input type="text" name="LNAME" id="mce-LNAME"
685
                               placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
686
                    </td>
687
                    <td>
688
                        <input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button"
689
                               value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
690
                    </td>
691
                </tr>
692
            </table>
693
        </form>
694
695
        <div style="position: absolute; left: -5000px;">
696
            <input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
697
        </div>
698
699
    </div>
700
701
    <script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>
702
    <script type='text/javascript'>(function ($) {
703
			window.fnames = new Array();
704
			window.ftypes = new Array();
705
			fnames[0] = 'EMAIL';
706
			ftypes[0] = 'email';
707
			fnames[1] = 'FNAME';
708
			ftypes[1] = 'text';
709
			fnames[2] = 'LNAME';
710
			ftypes[2] = 'text';
711
712
			//Successful submission
713
			$('form[name="mc-embedded-subscribe-form"]').on('submit', function () {
714
715
				var email_field = $(this).find('#mce-EMAIL').val();
716
				if (!email_field) {
717
					return false;
718
				}
719
				$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp();
720
				$(this).find('.give-newsletter-form').hide();
721
722
			});
723
724
725
		}(jQuery));
726
		var $mcj = jQuery.noConflict(true);
727
728
729
    </script>
730
    <!--End mc_embed_signup-->
731
732
<?php }
733
734
735
/**
736
 * Social Media Like Buttons
737
 *
738
 * Various social media elements to Give
739
 */
740
function give_social_media_elements() {
741
	?>
742
743
    <div class="social-items-wrap">
744
745
        <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"
746
                scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:100px; height:21px;"
747
                allowTransparency="true"></iframe>
748
749
        <a href="https://twitter.com/givewp" class="twitter-follow-button" data-show-count="false"><?php
750
			printf(
751
			/* translators: %s: Give twitter user @givewp */
752
				esc_html_e( 'Follow %s', 'give' ),
753
				'@givewp'
754
			);
755
			?></a>
756
        <script>!function (d, s, id) {
757
				var js, fjs = d.getElementsByTagName(s)[0], p = /^http:/.test(d.location) ? 'http' : 'https';
758
				if (!d.getElementById(id)) {
759
					js = d.createElement(s);
760
					js.id = id;
761
					js.src = p + '://platform.twitter.com/widgets.js';
762
					fjs.parentNode.insertBefore(js, fjs);
763
				}
764
			}(document, 'script', 'twitter-wjs');
765
        </script>
766
767
    </div>
768
    <!--/.social-items-wrap -->
769
770
	<?php
771
}
772
773
774
/**
775
 * Create SVG library function
776
 *
777
 * @param string $icon
778
 *
779
 * @return string
780
 */
781
function give_svg_icons( $icon ) {
782
783
	// Store your SVGs in an associative array
784
	$svgs = array(
785
		'microphone'    => '',
786
		'alert'         => "",
787
		'placemark'     => '',
788
		'give_grey'     => '',
789
		'give_cpt_icon' => '',
790
	);
791
792
	// Return the chosen icon's SVG string
793
	return $svgs[ $icon ];
794
}
795
796
/**
797
 * Modify Admin Nav Menu Label
798
 *
799
 * @since 1.3
800
 *
801
 * @param object $post_type The current object to add a menu items meta box for.
802
 *
803
 * @return mixed
804
 */
805
function modify_nav_menu_meta_box_object( $post_type ) {
806
	if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) {
807
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
808
	}
809
810
	return $post_type;
811
}
812
813
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
814
815
816
/**
817
 * Array_column backup usage
818
 *
819
 * This file is part of the array_column library.
820
 *
821
 * @since      : 1.3.0.1
822
 *
823
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
824
 * @license    https://opensource.org/licenses/MIT MIT
825
 */
826
827
if ( ! function_exists( 'array_column' ) ) {
828
	/**
829
	 * Returns the values from a single column of the input array, identified by
830
	 * the $columnKey.
831
	 *
832
	 * Optionally, you may provide an $indexKey to index the values in the returned
833
	 * array by the values from the $indexKey column in the input array.
834
	 *
835
	 * @param array      $input     A multi-dimensional array (record set) from which to pull
836
	 *                              a column of values.
837
	 * @param int|string $columnKey The column of values to return. This value may be the
838
	 *                              integer key of the column you wish to retrieve, or it
839
	 *                              may be the string key name for an associative array.
840
	 * @param mixed      $indexKey  (Optional.) The column to use as the index/keys for
841
	 *                              the returned array. This value may be the integer key
842
	 *                              of the column, or it may be the string key name.
843
	 *
844
	 * @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...
845
	 */
846
	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...
847
		// Using func_get_args() in order to check for proper number of
848
		// parameters and trigger errors exactly as the built-in array_column()
849
		// does in PHP 5.5.
850
		$argc   = func_num_args();
851
		$params = func_get_args();
852
853
		if ( $argc < 2 ) {
854
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
855
856
			return null;
857
		}
858
859
		if ( ! is_array( $params[0] ) ) {
860
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
861
862
			return null;
863
		}
864
865
		if ( ! is_int( $params[1] )
866
		     && ! is_float( $params[1] )
867
		     && ! is_string( $params[1] )
868
		     && $params[1] !== null
869
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
870
		) {
871
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
872
873
			return false;
874
		}
875
876
		if ( isset( $params[2] )
877
		     && ! is_int( $params[2] )
878
		     && ! is_float( $params[2] )
879
		     && ! is_string( $params[2] )
880
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
881
		) {
882
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
883
884
			return false;
885
		}
886
887
		$paramsInput     = $params[0];
888
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
889
890
		$paramsIndexKey = null;
891
		if ( isset( $params[2] ) ) {
892
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
893
				$paramsIndexKey = (int) $params[2];
894
			} else {
895
				$paramsIndexKey = (string) $params[2];
896
			}
897
		}
898
899
		$resultArray = array();
900
901
		foreach ( $paramsInput as $row ) {
902
			$key    = $value = null;
903
			$keySet = $valueSet = false;
904
905
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
906
				$keySet = true;
907
				$key    = (string) $row[ $paramsIndexKey ];
908
			}
909
910
			if ( $paramsColumnKey === null ) {
911
				$valueSet = true;
912
				$value    = $row;
913
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
914
				$valueSet = true;
915
				$value    = $row[ $paramsColumnKey ];
916
			}
917
918
			if ( $valueSet ) {
919
				if ( $keySet ) {
920
					$resultArray[ $key ] = $value;
921
				} else {
922
					$resultArray[] = $value;
923
				}
924
			}
925
926
		}
927
928
		return $resultArray;
929
	}
930
931
}
932
933
/**
934
 * Determines the receipt visibility status.
935
 *
936
 * @since 1.3.2
937
 *
938
 * @param string $payment_key
939
 *
940
 * @return bool Whether the receipt is visible or not.
941
 */
942
function give_can_view_receipt( $payment_key = '' ) {
943
944
	$return = false;
945
946
	if ( empty( $payment_key ) ) {
947
		return $return;
948
	}
949
950
	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...
951
952
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
953
954
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
955
956
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
957
958
	if ( is_user_logged_in() ) {
959
		if ( $user_id === (int) get_current_user_id() ) {
960
			$return = true;
961
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
962
			$return = true;
963
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
964
			$return = true;
965
		}
966
	}
967
968
	$session = give_get_purchase_session();
969
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
970
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
971
			$return = true;
972
		}
973
	}
974
975
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
976
977
}
978
979
/**
980
 * Fallback for cal_days_in_month
981
 *
982
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
983
 */
984
if ( ! function_exists( 'cal_days_in_month' ) ) {
985
	/**
986
	 * cal_days_in_month
987
	 *
988
	 * @param int $calendar
989
	 * @param int $month
990
	 * @param int $year
991
	 *
992
	 * @return bool|string
993
	 */
994
	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...
995
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
996
	}
997
}
998
999
/**
1000
 * Get plugin info including status, type, and license validation.
1001
 *
1002
 * This is an enhanced version of get_plugins() that returns the status
1003
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
1004
 * and license validation for Give add-ons (`true` or `false`). Does not include
1005
 * MU plugins.
1006
 *
1007
 * @since 1.8.0
1008
 *
1009
 * @return array Plugin info plus status, type, and license validation if
1010
 *               available.
1011
 */
1012
function give_get_plugins() {
1013
	$plugins             = get_plugins();
1014
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
1015
1016
	if ( is_multisite() ) {
1017
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
1018
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
1019
	}
1020
1021
	foreach ( $plugins as $plugin_path => $plugin_data ) {
1022
		// Is plugin active?
1023
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
1024
			$plugins[ $plugin_path ]['Status'] = 'active';
1025
		} else {
1026
			$plugins[ $plugin_path ]['Status'] = 'inactive';
1027
		}
1028
1029
		$dirname = strtolower( dirname( $plugin_path ) );
1030
1031
		// Is plugin a Give add-on by WordImpress?
1032
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
1033
			// Plugin is a Give-addon.
1034
			$plugins[ $plugin_path ]['Type'] = 'add-on';
1035
1036
			// Get license info from database.
1037
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
1038
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
1039
			$license_active = get_option( $db_option );
1040
1041
			// Does a valid license exist?
1042
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
1043
				$plugins[ $plugin_path ]['License'] = true;
1044
			} else {
1045
				$plugins[ $plugin_path ]['License'] = false;
1046
			}
1047
		} else {
1048
			// Plugin is not a Give add-on.
1049
			$plugins[ $plugin_path ]['Type'] = 'other';
1050
		}
1051
	}
1052
1053
	return $plugins;
1054
}
1055
1056
1057
/**
1058
 * Check if terms enabled or not for form.
1059
 *
1060
 * @since 1.8
1061
 *
1062
 * @param $form_id
1063
 *
1064
 * @return bool
1065
 */
1066
function give_is_terms_enabled( $form_id ) {
1067
	$form_option = give_get_meta( $form_id, '_give_terms_option', true );
1068
1069
	if (
1070
		give_is_setting_enabled( $form_option, 'global' )
1071
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1072
	) {
1073
		return true;
1074
1075
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1076
		return true;
1077
1078
	} else {
1079
		return false;
1080
	}
1081
}
1082
1083
1084
/**
1085
 * Delete donation stats cache.
1086
 * @todo Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key.
1087
 *
1088
 * @since 1.8.7
1089
 *
1090
 * @param string|array $date_range Date for stats.
1091
 *                           Date value should be in today, yesterday, this_week, last_week, this_month, last_month, this_quarter, last_quarter, this_year, last_year.
1092
 *                           For date value other, all cache will be removed.
1093
 *
1094
 * @param array  $args
1095
 *
1096
 * @return WP_Error|bool
1097
 */
1098
function give_delete_donation_stats( $date_range = '', $args = array() ) {
1099
	// Delete all cache.
1100
	$status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) );
1101
1102
	/**
1103
	 * Fire the action when donation stats delete.
1104
	 *
1105
	 * @since 1.8.7
1106
	 *
1107
	 * @param string|array $date_range
1108
	 * @param array  $args
1109
	 */
1110
	do_action( 'give_delete_donation_stats', $status, $date_range, $args );
1111
1112
	return $status;
1113
}
1114
1115
/**
1116
 * Check if admin creating new donation form or not.
1117
 *
1118
 * @since 2.0
1119
 * @return bool
1120
 */
1121
function give_is_add_new_form_page() {
1122
	$status = false;
1123
1124
	if ( false !== strpos( $_SERVER['REQUEST_URI'], '/wp-admin/post-new.php?post_type=give_forms' ) ) {
1125
		$status = true;
1126
	}
1127
1128
	return $status;
1129
}
1130
1131
/**
1132
 * Get Form/Payment meta.
1133
 * @todo: implement in core
1134
 *
1135
 * @since 1.8.8
1136
 *
1137
 * @param int    $id
1138
 * @param string $meta_key
1139
 * @param bool   $single
1140
 * @param bool   $default
1141
 *
1142
 * @return mixed
1143
 */
1144
function give_get_meta( $id, $meta_key, $single = false, $default = false ) {
1145
	$meta_value = get_post_meta( $id, $meta_key, $single );
1146
1147
	if (
1148
		( empty( $meta_key ) || empty( $meta_value ) )
1149
		&& $default
1150
	) {
1151
		$meta_value = $default;
1152
	}
1153
1154
1155
	return apply_filters( 'give_get_meta', $meta_value, $id, $meta_key, $default );
1156
}
1157
1158
/**
1159
 * Update Form/Payment meta.
1160
 * @todo: implement in core
1161
 *
1162
 * @since 1.8.8
1163
 *
1164
 * @param int    $id
1165
 * @param string $meta_key
1166
 * @param string $meta_value
1167
 * @param string $prev_value
1168
 *
1169
 * @return mixed
1170
 */
1171
function give_update_meta( $id, $meta_key, $meta_value, $prev_value = '' ) {
1172
	$status = update_post_meta( $id, $meta_key, $meta_value, $prev_value );
1173
1174
	return apply_filters( 'give_update_meta', $status, $id, $meta_key, $meta_value );
1175
}
1176
1177
/**
1178
 * Delete Form/Payment meta.
1179
 * @todo: implement in core
1180
 *
1181
 * @since 1.8.8
1182
 *
1183
 * @param int    $id
1184
 * @param string $meta_key
1185
 * @param string $meta_value
1186
 *
1187
 * @return mixed
1188
 */
1189
function give_delete_meta( $id, $meta_key, $meta_value = '' ) {
1190
	$status = delete_post_meta( $id, $meta_key, $meta_value );
1191
1192
	return apply_filters( 'give_delete_meta', $status, $id, $meta_key, $meta_value );
1193
}