Test Failed
Push — issues/1953 ( fc402a )
by Ravinder
05:33
created

misc-functions.php ➔ give_remove_pages_from_search()   A

Complexity

Conditions 4
Paths 2

Size

Total Lines 13
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 4
eloc 6
nc 2
nop 1
dl 0
loc 13
rs 9.2
c 0
b 0
f 0
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'] ) ) {
0 ignored issues
show
introduced by
Found "== 1". Use Yoda Condition checks, you must
Loading history...
276
		$ret = true;
277
	} elseif ( count( $gateways ) == 1 ) {
0 ignored issues
show
introduced by
Found "== 1". Use Yoda Condition checks, you must
Loading history...
278
		$ret = false;
279
	} elseif ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) {
0 ignored issues
show
introduced by
Found "== 2". Use Yoda Condition checks, you must
Loading history...
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 ) {
0 ignored issues
show
introduced by
Found "=== false". Use Yoda Condition checks, you must
Loading history...
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'];
0 ignored issues
show
introduced by
Detected usage of a non-sanitized input variable: $_SERVER
Loading history...
341
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
342
		// to check ip is pass from proxy
343
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
0 ignored issues
show
introduced by
Detected usage of a non-sanitized input variable: $_SERVER
Loading history...
344
	} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) {
0 ignored issues
show
introduced by
Due to using Batcache, server side based client related logic will not work, use JS instead.
Loading history...
345
		$ip = $_SERVER['REMOTE_ADDR'];
0 ignored issues
show
introduced by
Detected usage of a non-sanitized input variable: $_SERVER
Loading history...
introduced by
Due to using Batcache, server side based client related logic will not work, use JS instead.
Loading history...
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 );
0 ignored issues
show
Documentation introduced by
$purchase_data is of type array, but the function expects a string.

It seems like the type of the argument is not accepted by the function/method which you are calling.

In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.

We suggest to add an explicit type cast like in the following example:

function acceptsInteger($int) { }

$x = '123'; // string "123"

// Instead of
acceptsInteger($x);

// we recommend to use
acceptsInteger((integer) $x);
Loading history...
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'] ) ) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
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'] ) ) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
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;
0 ignored issues
show
Unused Code introduced by
$host is not used, you could remove the assignment.

This check looks for variable assignements that are either overwritten by other assignments or where the variable is not used subsequently.

$myVar = 'Value';
$higher = false;

if (rand(1, 6) > 3) {
    $higher = true;
} else {
    $higher = false;
}

Both the $myVar assignment in line 1 and the $higher assignment in line 2 are dead. The first because $myVar is never used and the second because $higher is always overwritten for every possible time line.

Loading history...
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' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
448
		$host = 'ICDSoft';
449
	} elseif ( DB_HOST == 'mysqlv5' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
450
		$host = 'NetworkSolutions';
451
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
452
		$host = 'iPage';
453
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
454
		$host = 'IPower';
455
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
456
		$host = 'MediaTemple Grid';
457
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
458
		$host = 'pair Networks';
459
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
460
		$host = 'Rackspace Cloud';
461
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
462
		$host = 'SysFix.eu Power Hosting';
463
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
464
		$host = 'Flywheel';
465
	} else {
466
		// Adding a general fallback for data gathering
467
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
0 ignored issues
show
introduced by
Detected usage of a non-sanitized input variable: $_SERVER
Loading history...
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' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
503
					$return = true;
504
				}
505
				break;
506
			case 'networksolutions':
507
				if ( DB_HOST == 'mysqlv5' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
508
					$return = true;
509
				}
510
				break;
511
			case 'ipage':
512
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
513
					$return = true;
514
				}
515
				break;
516
			case 'ipower':
517
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
518
					$return = true;
519
				}
520
				break;
521
			case 'mediatemplegrid':
522
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
523
					$return = true;
524
				}
525
				break;
526
			case 'pairnetworks':
527
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
528
					$return = true;
529
				}
530
				break;
531
			case 'rackspacecloud':
532
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
533
					$return = true;
534
				}
535
				break;
536
			case 'sysfix.eu':
537
			case 'sysfix.eupowerhosting':
538
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
539
					$return = true;
540
				}
541
				break;
542
			case 'flywheel':
543
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
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.
0 ignored issues
show
introduced by
The use of function print_r() is discouraged
Loading history...
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.
0 ignored issues
show
introduced by
The use of function print_r() is discouraged
Loading history...
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'] )
0 ignored issues
show
introduced by
Detected access of super global var $_REQUEST, probably need manual inspection.
Loading history...
616
		? absint( $_REQUEST['post'] )
0 ignored issues
show
introduced by
Detected access of super global var $_REQUEST, probably need manual inspection.
Loading history...
617
		: null;
618
619
	$post_id = ! empty( $post_id )
620
		? $post_id
621
		: ( isset( $_REQUEST['post_id'] ) ? absint( $_REQUEST['post_id'] ) : null );
0 ignored issues
show
introduced by
Detected access of super global var $_REQUEST, probably need manual inspection.
Loading history...
622
623
	$post_id = ! empty( $post_id )
624
		? $post_id
625
		: ( isset( $_REQUEST['post_ID'] ) ? absint( $_REQUEST['post_ID'] ) : null );
0 ignored issues
show
introduced by
Detected access of super global var $_REQUEST, probably need manual inspection.
Loading history...
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>
0 ignored issues
show
introduced by
Scripts must be registered/enqueued via wp_enqueue_script
Loading history...
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' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
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 ) {
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...
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] )
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
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] )
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
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 ) {
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...
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
/**
1226
 * Get attribute string
1227
 *
1228
 * @since 2.0
1229
 *
1230
 * @param array $attributes
1231
 *
1232
 * @return string
1233
 */
1234
function give_get_attribute_str( $attributes ) {
1235
	$attribute_str = '';
1236
1237
	if ( empty( $attributes ) ) {
1238
		return $attribute_str;
1239
	}
1240
1241
	foreach ( $attributes as $tag => $value ) {
1242
		$attribute_str .= " {$tag}=\"{$value}\"";
1243
	}
1244
1245
	return trim( $attribute_str );
1246
}
1247
1248
1249
/**
1250
 * Check if the upgrade routine has been run for a specific action
1251
 *
1252
 * @since  1.0
1253
 *
1254
 * @param  string $upgrade_action The upgrade action to check completion for
1255
 *
1256
 * @return bool                   If the action has been added to the completed actions array
1257
 */
1258
function give_has_upgrade_completed( $upgrade_action = '' ) {
1259
1260
	if ( empty( $upgrade_action ) ) {
1261
		return false;
1262
	}
1263
1264
	$completed_upgrades = give_get_completed_upgrades();
1265
1266
	return in_array( $upgrade_action, $completed_upgrades );
1267
1268
}
1269
1270
/**
1271
 * For use when doing 'stepped' upgrade routines, to see if we need to start somewhere in the middle
1272
 *
1273
 * @since 1.8
1274
 *
1275
 * @return mixed   When nothing to resume returns false, otherwise starts the upgrade where it left off
1276
 */
1277
function give_maybe_resume_upgrade() {
1278
	$doing_upgrade = get_option( 'give_doing_upgrade', false );
1279
	if ( empty( $doing_upgrade ) ) {
1280
		return false;
1281
	}
1282
1283
	return $doing_upgrade;
1284
}
1285
1286
/**
1287
 * Adds an upgrade action to the completed upgrades array
1288
 *
1289
 * @since  1.0
1290
 *
1291
 * @param  string $upgrade_action The action to add to the completed upgrades array
1292
 *
1293
 * @return bool                   If the function was successfully added
1294
 */
1295
function give_set_upgrade_complete( $upgrade_action = '' ) {
1296
1297
	if ( empty( $upgrade_action ) ) {
1298
		return false;
1299
	}
1300
1301
	$completed_upgrades   = give_get_completed_upgrades();
1302
	$completed_upgrades[] = $upgrade_action;
1303
1304
	// Remove any blanks, and only show uniques.
1305
	$completed_upgrades = array_unique( array_values( $completed_upgrades ) );
1306
1307
	/**
1308
	 * Fire the action when any upgrade set to complete.
1309
	 *
1310
	 * @since 1.8.12
1311
	 */
1312
	do_action( 'give_set_upgrade_completed', $upgrade_action, $completed_upgrades );
1313
1314
	return update_option( 'give_completed_upgrades', $completed_upgrades );
1315
}
1316
1317
/**
1318
 * Get's the array of completed upgrade actions
1319
 *
1320
 * @since  1.0
1321
 * @return array The array of completed upgrades
1322
 */
1323
function give_get_completed_upgrades() {
1324
	return (array) get_option( 'give_completed_upgrades' );
1325
}
1326
1327
/**
1328
 * In 2.0 we updated table for log, payment and form.
1329
 *
1330
 * Note: internal purpose only.
1331
 *
1332
 * @since 2.0
1333
 * @global wpdb  $wpdb
1334
 *
1335
 * @param string $type Context for table
1336
 *
1337
 * @return null|array
1338
 */
1339
function __give_v20_bc_table_details( $type ) {
1340
	global $wpdb;
1341
	$table = array();
1342
1343
	// Bailout.
1344
	if ( empty( $type ) ) {
1345
		return null;
1346
	}
1347
1348
	switch ( $type ) {
1349
		case 'form':
1350
			$table['name']         = $wpdb->formmeta;
1351
			$table['column']['id'] = 'form_id';
1352
1353
			break;
1354
1355
		case 'payment':
1356
			$table['name']         = $wpdb->paymentmeta;
1357
			$table['column']['id'] = 'payment_id';
1358
	}
1359
1360
	// Backward compatibility.
1361
	if ( ! give_has_upgrade_completed( 'v20_move_metadata_into_new_table' ) ) {
1362
		$table['name']         = $wpdb->postmeta;
1363
		$table['column']['id'] = 'post_id';
1364
	}
1365
0 ignored issues
show
Coding Style introduced by
Functions must not contain multiple empty lines in a row; found 2 empty lines
Loading history...
1366
1367
	return $table;
1368
}
1369
1370
/**
1371
 * Remove the Give transaction pages from WP search results.
1372
 *
1373
 * @since 1.8.13
1374
 *
1375
 * @param \WP_Query
1376
 *
1377
 */
1378
function give_remove_pages_from_search( $query ) {
1379
1380
	if ( ! $query->is_admin && $query->is_search && $query->is_main_query() ) {
1381
1382
		$transaction_failed = give_get_option( 'failure_page', 0 );
1383
		$success_page       = give_get_option( 'success_page', 0 );
1384
		$args = apply_filters( 'give_remove_pages_from_search', array( $transaction_failed, $success_page ), $query );
1385
1386
		$query->set( 'post__not_in', $args );
1387
	}
1388
0 ignored issues
show
Coding Style introduced by
Functions must not contain multiple empty lines in a row; found 2 empty lines
Loading history...
1389
1390
}
1391
1392
add_action( 'pre_get_posts', 'give_remove_pages_from_search', 10, 1 );
1393