Test Failed
Push — issues/370 ( 90279e )
by Ravinder
05:35
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
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
 * Generate Item Title for Payment Gateway.
384
 *
385
 * @param array $payment_data Payment Data.
386
 *
387
 * @since 1.8.14
388
 *
389
 * @return string
390
 */
391
function give_payment_gateway_item_title( $payment_data ) {
392
	$form_id          = intval( $payment_data['post_data']['give-form-id'] );
393
	$item_name        = $payment_data['post_data']['give-form-title'];
394
	$is_custom_amount = give_is_setting_enabled( give_get_meta( $form_id, '_give_custom_amount', true ) );
395
396
	// Verify has variable prices.
397
	if ( give_has_variable_prices( $form_id ) && isset( $payment_data['post_data']['give-price-id'] ) ) {
398
399
		$item_price_level_text = give_get_price_option_name( $form_id, $payment_data['post_data']['give-price-id'] );
400
		$price_level_amount    = give_get_price_option_amount( $form_id, $payment_data['post_data']['give-price-id'] );
401
402
		// Donation given doesn't match selected level (must be a custom amount).
403
		if ( $price_level_amount !== give_maybe_sanitize_amount( $payment_data['post_data']['give-amount'] ) ) {
404
			$custom_amount_text = give_get_meta( $form_id, '_give_custom_amount_text', true );
405
406
			// user custom amount text if any, fallback to default if not.
407
			$item_name .= ' - ' . give_check_variable( $custom_amount_text, 'empty', __( 'Custom Amount', 'give' ) );
408
409
		} elseif ( ! empty( $item_price_level_text ) ) {
410
			$item_name .= ' - ' . $item_price_level_text;
411
		}
412
	} // End if().
413
	elseif ( $is_custom_amount && give_get_form_price( $form_id ) !== give_maybe_sanitize_amount( $payment_data['post_data']['give-amount'] ) ) {
414
		$custom_amount_text = give_get_meta( $form_id, '_give_custom_amount_text', true );
415
		// user custom amount text if any, fallback to default if not.
416
		$item_name .= ' - ' . give_check_variable( $custom_amount_text, 'empty', __( 'Custom Amount', 'give' ) );
417
	}
418
419
	/**
420
	 * Filter the Item Title of Payment Gateway.
421
	 *
422
	 * @param string $item_name    Item Title of Payment Gateway.
423
	 * @param int    $form_id      Donation Form ID.
424
	 * @param array  $payment_data Payment Data.
425
	 *
426
	 * @since 1.8.14
427
	 *
428
	 * @return string
429
	 */
430
	return apply_filters( 'give_payment_gateway_item_title', $item_name, $form_id, $payment_data );
431
}
432
433
/**
434
 * Get Donation Summary
435
 *
436
 * Creates a donation summary for payment gateways from the donation data before the payment is created in the database.
437
 *
438
 * @since       1.8.12
439
 *
440
 * @param array $donation_data
441
 * @param bool  $name_and_email
442
 * @param int   $length
443
 *
444
 * @return string
445
 */
446
function give_payment_gateway_donation_summary( $donation_data, $name_and_email = true, $length = 255 ) {
447
	$form_id = isset( $donation_data['post_data']['give-form-id'] ) ? $donation_data['post_data']['give-form-id'] : '';
448
449
	// Form title.
450
	$summary = ( ! empty( $donation_data['post_data']['give-form-title'] ) ? $donation_data['post_data']['give-form-title'] : ( ! empty( $form_id ) ? wp_sprintf( __( 'Donation Form ID: %d', 'give' ), $form_id ) : __( 'Untitled donation form', 'give' ) ) );
451
452
	// Form multilevel if applicable.
453
	if ( isset( $donation_data['post_data']['give-price-id'] ) ) {
454
		$summary .= ': ' . give_get_price_option_name( $form_id, $donation_data['post_data']['give-price-id'] );
455
	}
456
457
	// Add Donor's name + email if requested.
458
	if ( $name_and_email ) {
459
460
		// First name
461 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...
462
			$summary .= ' - ' . $donation_data['user_info']['first_name'];
463
		}
464
465 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...
466
			$summary .= ' ' . $donation_data['user_info']['last_name'];
467
		}
468
469
		$summary .= ' (' . $donation_data['user_email'] . ')';
470
	}
471
472
	// Cut the length
473
	$summary = substr( $summary, 0, $length );
474
475
	return apply_filters( 'give_payment_gateway_donation_summary', $summary );
476
}
477
478
479
/**
480
 * Get user host
481
 *
482
 * Returns the webhost this site is using if possible
483
 *
484
 * @since 1.0
485
 * @return string $host if detected, false otherwise
486
 */
487
function give_get_host() {
488
	$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...
489
490
	if ( defined( 'WPE_APIKEY' ) ) {
491
		$host = 'WP Engine';
492
	} elseif ( defined( 'PAGELYBIN' ) ) {
493
		$host = 'Pagely';
494
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
495
		$host = 'ICDSoft';
496
	} elseif ( DB_HOST == 'mysqlv5' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
497
		$host = 'NetworkSolutions';
498
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
499
		$host = 'iPage';
500
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
501
		$host = 'IPower';
502
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
503
		$host = 'MediaTemple Grid';
504
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
505
		$host = 'pair Networks';
506
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
507
		$host = 'Rackspace Cloud';
508
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
509
		$host = 'SysFix.eu Power Hosting';
510
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
511
		$host = 'Flywheel';
512
	} else {
513
		// Adding a general fallback for data gathering
514
		$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...
515
	}
516
517
	return $host;
518
}
519
520
521
/**
522
 * Check site host
523
 *
524
 * @since 1.0
525
 *
526
 * @param bool /string $host The host to check
527
 *
528
 * @return bool true if host matches, false if not
529
 */
530
function give_is_host( $host = false ) {
531
532
	$return = false;
533
534
	if ( $host ) {
535
		$host = str_replace( ' ', '', strtolower( $host ) );
536
537
		switch ( $host ) {
538
			case 'wpengine':
539
				if ( defined( 'WPE_APIKEY' ) ) {
540
					$return = true;
541
				}
542
				break;
543
			case 'pagely':
544
				if ( defined( 'PAGELYBIN' ) ) {
545
					$return = true;
546
				}
547
				break;
548
			case 'icdsoft':
549
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
550
					$return = true;
551
				}
552
				break;
553
			case 'networksolutions':
554
				if ( DB_HOST == 'mysqlv5' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
555
					$return = true;
556
				}
557
				break;
558
			case 'ipage':
559
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
560
					$return = true;
561
				}
562
				break;
563
			case 'ipower':
564
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
565
					$return = true;
566
				}
567
				break;
568
			case 'mediatemplegrid':
569
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
570
					$return = true;
571
				}
572
				break;
573
			case 'pairnetworks':
574
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
575
					$return = true;
576
				}
577
				break;
578
			case 'rackspacecloud':
579
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
580
					$return = true;
581
				}
582
				break;
583
			case 'sysfix.eu':
584
			case 'sysfix.eupowerhosting':
585
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
586
					$return = true;
587
				}
588
				break;
589
			case 'flywheel':
590
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
591
					$return = true;
592
				}
593
				break;
594
			default:
595
				$return = false;
596
		}// End switch().
597
	}// End if().
598
599
	return $return;
600
}
601
602
/**
603
 * Marks a function as deprecated and informs when it has been used.
604
 *
605
 * There is a hook give_deprecated_function_run that will be called that can be used
606
 * to get the backtrace up to what file and function called the deprecated
607
 * function.
608
 *
609
 * The current behavior is to trigger a user error if WP_DEBUG is true.
610
 *
611
 * This function is to be used in every function that is deprecated.
612
 *
613
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
614
 *   and the version the function was deprecated in.
615
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
616
 *   trigger or false to not trigger error.
617
 *
618
 * @param string $function    The function that was called.
619
 * @param string $version     The plugin version that deprecated the function.
620
 * @param string $replacement Optional. The function that should have been called.
621
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
622
 */
623
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
624
625
	/**
626
	 * Fires while give deprecated function call occurs.
627
	 *
628
	 * Allow you to hook to deprecated function call.
629
	 *
630
	 * @since 1.0
631
	 *
632
	 * @param string $function    The function that was called.
633
	 * @param string $replacement Optional. The function that should have been called.
634
	 * @param string $version     The plugin version that deprecated the function.
635
	 */
636
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
637
638
	$show_errors = current_user_can( 'manage_options' );
639
640
	// Allow plugin to filter the output error trigger.
641
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
642
		if ( ! is_null( $replacement ) ) {
643
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
644
			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...
645
			// Alternatively we could dump this to a file.
646
		} else {
647
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
648
			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...
649
			// Alternatively we could dump this to a file.
650
		}
651
	}
652
}
653
654
/**
655
 * Give Get Admin ID
656
 *
657
 * Helper function to return the ID of the post for admin usage
658
 *
659
 * @return string $post_id
660
 */
661
function give_get_admin_post_id() {
662
	$post_id = isset( $_REQUEST['post'] )
0 ignored issues
show
introduced by
Detected access of super global var $_REQUEST, probably need manual inspection.
Loading history...
663
		? absint( $_REQUEST['post'] )
0 ignored issues
show
introduced by
Detected access of super global var $_REQUEST, probably need manual inspection.
Loading history...
664
		: null;
665
666
	$post_id = ! empty( $post_id )
667
		? $post_id
668
		: ( 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...
669
670
	$post_id = ! empty( $post_id )
671
		? $post_id
672
		: ( 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...
673
674
	return $post_id;
675
}
676
677
/**
678
 * Get PHP Arg Separator Output
679
 *
680
 * @since 1.0
681
 * @return string Arg separator output
682
 */
683
function give_get_php_arg_separator_output() {
684
	return ini_get( 'arg_separator.output' );
685
}
686
687
688
/**
689
 * Month Num To Name
690
 *
691
 * Takes a month number and returns the name three letter name of it.
692
 *
693
 * @since 1.0
694
 *
695
 * @param int $n
696
 *
697
 * @return string Short month name
698
 */
699
function give_month_num_to_name( $n ) {
700
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
701
702
	return date_i18n( 'M', $timestamp );
703
}
704
705
706
/**
707
 * Checks whether function is disabled.
708
 *
709
 * @since 1.0
710
 *
711
 * @param string $function Name of the function.
712
 *
713
 * @return bool Whether or not function is disabled.
714
 */
715
function give_is_func_disabled( $function ) {
716
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
717
718
	return in_array( $function, $disabled );
719
}
720
721
722
/**
723
 * Give Newsletter
724
 *
725
 * Returns the main Give newsletter form
726
 */
727
function give_get_newsletter() {
728
	?>
729
730
	<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>
731
732
	<div class="give-newsletter-form-wrap">
733
734
		<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13"
735
		      method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate"
736
		      target="_blank" novalidate>
737
			<div class="give-newsletter-confirmation">
738
				<p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
739
			</div>
740
741
			<table class="form-table give-newsletter-form">
742
				<tr valign="middle">
743
					<td>
744
						<label for="mce-EMAIL"
745
						       class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
746
						<input type="email" name="EMAIL" id="mce-EMAIL"
747
						       placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>"
748
						       class="required email" value="">
749
					</td>
750
					<td>
751
						<label for="mce-FNAME"
752
						       class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
753
						<input type="text" name="FNAME" id="mce-FNAME"
754
						       placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
755
					</td>
756
					<td>
757
						<label for="mce-LNAME"
758
						       class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
759
						<input type="text" name="LNAME" id="mce-LNAME"
760
						       placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
761
					</td>
762
					<td>
763
						<input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button"
764
						       value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
765
					</td>
766
				</tr>
767
			</table>
768
		</form>
769
770
		<div style="position: absolute; left: -5000px;">
771
			<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
772
		</div>
773
774
	</div>
775
776
	<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...
777
	<script type='text/javascript'>(function ($) {
778
			window.fnames = new Array();
779
			window.ftypes = new Array();
780
			fnames[0] = 'EMAIL';
781
			ftypes[0] = 'email';
782
			fnames[1] = 'FNAME';
783
			ftypes[1] = 'text';
784
			fnames[2] = 'LNAME';
785
			ftypes[2] = 'text';
786
787
			//Successful submission
788
			$('form[name="mc-embedded-subscribe-form"]').on('submit', function () {
789
790
				var email_field = $(this).find('#mce-EMAIL').val();
791
				if (!email_field) {
792
					return false;
793
				}
794
				$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp();
795
				$(this).find('.give-newsletter-form').hide();
796
797
			});
798
799
		}(jQuery));
800
		var $mcj = jQuery.noConflict(true);
801
802
803
	</script>
804
	<!--End mc_embed_signup-->
805
806
<?php }
807
808
809
/**
810
 * Create SVG library function
811
 *
812
 * @param string $icon
813
 *
814
 * @return string
815
 */
816
function give_svg_icons( $icon ) {
817
818
	// Store your SVGs in an associative array
819
	$svgs = array(
820
		'microphone'    => '',
821
		'alert'         => '',
822
		'placemark'     => '',
823
		'give_grey'     => '',
824
		'give_cpt_icon' => '',
825
	);
826
827
	// Return the chosen icon's SVG string
828
	return $svgs[ $icon ];
829
}
830
831
/**
832
 * Modify Admin Nav Menu Label
833
 *
834
 * @since 1.3
835
 *
836
 * @param object $post_type The current object to add a menu items meta box for.
837
 *
838
 * @return mixed
839
 */
840
function modify_nav_menu_meta_box_object( $post_type ) {
841
	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...
842
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
843
	}
844
845
	return $post_type;
846
}
847
848
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
849
850
/**
851
 * Show Donation Forms Post Type in Appearance > Menus by default on fresh install.
852
 *
853
 * @since 1.8.14
854
 *
855
 * @todo Remove this, when WordPress Core ticket is resolved (https://core.trac.wordpress.org/ticket/16828).
856
 *
857
 * @return bool
858
 */
859
function give_donation_metabox_menu() {
860
861
	// Get Current Screen.
862
	$screen = get_current_screen();
863
864
	// Proceed, if current screen is navigation menus.
865
	if(
0 ignored issues
show
introduced by
Space after opening control structure is required
Loading history...
introduced by
No space before opening parenthesis is prohibited
Loading history...
866
		'nav-menus' === $screen->id &&
867
		give_is_setting_enabled( give_get_option( 'forms_singular' ) ) &&
868
		! get_user_option( 'give_is_donation_forms_menu_updated' )
869
	) {
870
871
		// Return false, if it fails to retrieve hidden meta box list and is not admin.
872
		if (
873
			! is_admin() ||
874
			( ! $hidden_meta_boxes = get_user_option( 'metaboxhidden_nav-menus' ) )
875
		) {
876
			return false;
877
		}
878
879
		// Return false, In case, we don't find 'Donation Form' in hidden meta box list.
880
		if ( ! in_array( 'add-post-type-give_forms', $hidden_meta_boxes, true ) ) {
881
			return false;
882
		}
883
884
		// Exclude 'Donation Form' value from hidden meta box's list.
885
		$hidden_meta_boxes = array_diff( $hidden_meta_boxes, array( 'add-post-type-give_forms' ) );
886
887
		// Get current user ID.
888
		$user = wp_get_current_user();
889
890
		update_user_option( $user->ID, 'metaboxhidden_nav-menus', $hidden_meta_boxes, true );
891
		update_user_option( $user->ID, 'give_is_donation_forms_menu_updated', true, true );
892
	}
893
}
894
895
add_action( 'current_screen', 'give_donation_metabox_menu' );
896
897
/**
898
 * Array_column backup usage
899
 *
900
 * This file is part of the array_column library.
901
 *
902
 * @since      : 1.3.0.1
903
 *
904
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
905
 * @license    https://opensource.org/licenses/MIT MIT
906
 */
907
908
if ( ! function_exists( 'array_column' ) ) {
909
	/**
910
	 * Returns the values from a single column of the input array, identified by
911
	 * the $columnKey.
912
	 *
913
	 * Optionally, you may provide an $indexKey to index the values in the returned
914
	 * array by the values from the $indexKey column in the input array.
915
	 *
916
	 * @param array      $input     A multi-dimensional array (record set) from which to pull
917
	 *                              a column of values.
918
	 * @param int|string $columnKey The column of values to return. This value may be the
919
	 *                              integer key of the column you wish to retrieve, or it
920
	 *                              may be the string key name for an associative array.
921
	 * @param mixed      $indexKey  (Optional.) The column to use as the index/keys for
922
	 *                              the returned array. This value may be the integer key
923
	 *                              of the column, or it may be the string key name.
924
	 *
925
	 * @return array
926
	 */
927
	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...
928
		// Using func_get_args() in order to check for proper number of
929
		// parameters and trigger errors exactly as the built-in array_column()
930
		// does in PHP 5.5.
931
		$argc   = func_num_args();
932
		$params = func_get_args();
933
934
		if ( $argc < 2 ) {
935
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
936
937
			return null;
938
		}
939
940
		if ( ! is_array( $params[0] ) ) {
941
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
942
943
			return null;
944
		}
945
946 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...
947
		     && ! is_float( $params[1] )
948
		     && ! is_string( $params[1] )
949
		     && $params[1] !== null
950
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
951
		) {
952
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
953
954
			return false;
955
		}
956
957 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...
958
		     && ! is_int( $params[2] )
959
		     && ! is_float( $params[2] )
960
		     && ! is_string( $params[2] )
961
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
962
		) {
963
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
964
965
			return false;
966
		}
967
968
		$paramsInput     = $params[0];
969
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
970
971
		$paramsIndexKey = null;
972
		if ( isset( $params[2] ) ) {
973
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
974
				$paramsIndexKey = (int) $params[2];
975
			} else {
976
				$paramsIndexKey = (string) $params[2];
977
			}
978
		}
979
980
		$resultArray = array();
981
982
		foreach ( $paramsInput as $row ) {
983
			$key    = $value = null;
984
			$keySet = $valueSet = false;
985
986
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
987
				$keySet = true;
988
				$key    = (string) $row[ $paramsIndexKey ];
989
			}
990
991
			if ( $paramsColumnKey === null ) {
992
				$valueSet = true;
993
				$value    = $row;
994
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
995
				$valueSet = true;
996
				$value    = $row[ $paramsColumnKey ];
997
			}
998
999
			if ( $valueSet ) {
1000
				if ( $keySet ) {
1001
					$resultArray[ $key ] = $value;
1002
				} else {
1003
					$resultArray[] = $value;
1004
				}
1005
			}
1006
		}
1007
1008
		return $resultArray;
1009
	}
1010
}// End if().
1011
1012
/**
1013
 * Determines the receipt visibility status.
1014
 *
1015
 * @since 1.3.2
1016
 *
1017
 * @param string $payment_key
1018
 *
1019
 * @return bool Whether the receipt is visible or not.
1020
 */
1021
function give_can_view_receipt( $payment_key = '' ) {
1022
1023
	$return = false;
1024
1025
	if ( empty( $payment_key ) ) {
1026
		return $return;
1027
	}
1028
1029
	global $give_receipt_args;
1030
1031
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
1032
1033
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
1034
1035
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
1036
1037
	if ( is_user_logged_in() ) {
1038
		if ( $user_id === (int) get_current_user_id() ) {
1039
			$return = true;
1040
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
1041
			$return = true;
1042
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
1043
			$return = true;
1044
		}
1045
	}
1046
1047
	$session = give_get_purchase_session();
1048
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
1049
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
1050
			$return = true;
1051
		}
1052
	}
1053
1054
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
1055
1056
}
1057
1058
/**
1059
 * Fallback for cal_days_in_month
1060
 *
1061
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
1062
 */
1063
if ( ! function_exists( 'cal_days_in_month' ) ) {
1064
	/**
1065
	 * cal_days_in_month
1066
	 *
1067
	 * @param int $calendar
1068
	 * @param int $month
1069
	 * @param int $year
1070
	 *
1071
	 * @return bool|string
1072
	 */
1073
	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...
1074
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
1075
	}
1076
}
1077
1078
/**
1079
 * Get plugin info including status, type, and license validation.
1080
 *
1081
 * This is an enhanced version of get_plugins() that returns the status
1082
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
1083
 * and license validation for Give add-ons (`true` or `false`). Does not include
1084
 * MU plugins.
1085
 *
1086
 * @since 1.8.0
1087
 *
1088
 * @return array Plugin info plus status, type, and license validation if
1089
 *               available.
1090
 */
1091
function give_get_plugins() {
1092
	$plugins             = get_plugins();
1093
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
1094
1095
	if ( is_multisite() ) {
1096
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
1097
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
1098
	}
1099
1100
	foreach ( $plugins as $plugin_path => $plugin_data ) {
1101
		// Is plugin active?
1102
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
1103
			$plugins[ $plugin_path ]['Status'] = 'active';
1104
		} else {
1105
			$plugins[ $plugin_path ]['Status'] = 'inactive';
1106
		}
1107
1108
		$dirname = strtolower( dirname( $plugin_path ) );
1109
1110
		// Is plugin a Give add-on by WordImpress?
1111
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
1112
			// Plugin is a Give-addon.
1113
			$plugins[ $plugin_path ]['Type'] = 'add-on';
1114
1115
			// Get license info from database.
1116
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
1117
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
1118
			$license_active = get_option( $db_option );
1119
1120
			// Does a valid license exist?
1121
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
1122
				$plugins[ $plugin_path ]['License'] = true;
1123
			} else {
1124
				$plugins[ $plugin_path ]['License'] = false;
1125
			}
1126
		} else {
1127
			// Plugin is not a Give add-on.
1128
			$plugins[ $plugin_path ]['Type'] = 'other';
1129
		}
1130
	}
1131
1132
	return $plugins;
1133
}
1134
1135
1136
/**
1137
 * Check if terms enabled or not for form.
1138
 *
1139
 * @since 1.8
1140
 *
1141
 * @param $form_id
1142
 *
1143
 * @return bool
1144
 */
1145
function give_is_terms_enabled( $form_id ) {
1146
	$form_option = give_get_meta( $form_id, '_give_terms_option', true );
1147
1148
	if (
1149
		give_is_setting_enabled( $form_option, 'global' )
1150
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1151
	) {
1152
		return true;
1153
1154
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1155
		return true;
1156
1157
	} else {
1158
		return false;
1159
	}
1160
}
1161
1162
1163
/**
1164
 * Delete donation stats cache.
1165
 *
1166
 * @todo  Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key.
1167
 *
1168
 * @since 1.8.7
1169
 *
1170
 * @param string|array $date_range Date for stats.
1171
 *                                 Date value should be in today, yesterday, this_week, last_week, this_month, last_month, this_quarter, last_quarter, this_year, last_year.
1172
 *                                 For date value other, all cache will be removed.
1173
 *
1174
 * @param array $args
1175
 *
1176
 * @return WP_Error|bool
1177
 */
1178
function give_delete_donation_stats( $date_range = '', $args = array() ) {
1179
	// Delete all cache.
1180
	$status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) );
1181
1182
	/**
1183
	 * Fire the action when donation stats delete.
1184
	 *
1185
	 * @since 1.8.7
1186
	 *
1187
	 * @param string|array $date_range
1188
	 * @param array $args
1189
	 */
1190
	do_action( 'give_delete_donation_stats', $status, $date_range, $args );
1191
1192
	return $status;
1193
}
1194
1195
/**
1196
 * Check if admin creating new donation form or not.
1197
 *
1198
 * @since 2.0
1199
 * @return bool
1200
 */
1201
function give_is_add_new_form_page() {
1202
	$status = false;
1203
1204
	if ( false !== strpos( $_SERVER['REQUEST_URI'], '/wp-admin/post-new.php?post_type=give_forms' ) ) {
1205
		$status = true;
1206
	}
1207
1208
	return $status;
1209
}
1210
1211
/**
1212
 * Get Form/Payment meta.
1213
 *
1214
 * @since 1.8.8
1215
 *
1216
 * @param int    $id
1217
 * @param string $meta_key
1218
 * @param bool   $single
1219
 * @param bool   $default
1220
 *
1221
 * @return mixed
1222
 */
1223
function give_get_meta( $id, $meta_key = '', $single = false, $default = false ) {
1224
	/**
1225
	 * Filter the meta value
1226
	 *
1227
	 * @since 1.8.8
1228
	 */
1229
	$meta_value = apply_filters(
1230
		'give_get_meta',
1231
		get_post_meta( $id, $meta_key, $single ),
1232
		$id,
1233
		$meta_key,
1234
		$default
1235
	);
1236
1237
	if (
1238
		( empty( $meta_key ) || empty( $meta_value ) )
1239
		&& $default
1240
	) {
1241
		$meta_value = $default;
1242
	}
1243
1244
	return $meta_value;
1245
}
1246
1247
/**
1248
 * Update Form/Payment meta.
1249
 *
1250
 * @since 1.8.8
1251
 *
1252
 * @param int    $id
1253
 * @param string $meta_key
1254
 * @param string $meta_value
1255
 * @param string $prev_value
1256
 *
1257
 * @return mixed
1258
 */
1259
function give_update_meta( $id, $meta_key, $meta_value, $prev_value = '' ) {
1260
	$status = update_post_meta( $id, $meta_key, $meta_value, $prev_value );
1261
1262
	/**
1263
	 * Filter the meta value update status
1264
	 *
1265
	 * @since 1.8.8
1266
	 */
1267
	return apply_filters( 'give_update_meta', $status, $id, $meta_key, $meta_value );
1268
}
1269
1270
/**
1271
 * Delete Form/Payment meta.
1272
 *
1273
 * @since 1.8.8
1274
 *
1275
 * @param int    $id
1276
 * @param string $meta_key
1277
 * @param string $meta_value
1278
 *
1279
 * @return mixed
1280
 */
1281
function give_delete_meta( $id, $meta_key, $meta_value = '' ) {
1282
	$status = delete_post_meta( $id, $meta_key, $meta_value );
1283
1284
	/**
1285
	 * Filter the meta value delete status
1286
	 *
1287
	 * @since 1.8.8
1288
	 */
1289
	return apply_filters( 'give_delete_meta', $status, $id, $meta_key, $meta_value );
1290
}
1291
1292
/**
1293
 * Check if the upgrade routine has been run for a specific action
1294
 *
1295
 * @since  1.0
1296
 *
1297
 * @param  string $upgrade_action The upgrade action to check completion for
1298
 *
1299
 * @return bool                   If the action has been added to the completed actions array
1300
 */
1301
function give_has_upgrade_completed( $upgrade_action = '' ) {
1302
1303
	if ( empty( $upgrade_action ) ) {
1304
		return false;
1305
	}
1306
1307
	$completed_upgrades = give_get_completed_upgrades();
1308
1309
	return in_array( $upgrade_action, $completed_upgrades );
1310
1311
}
1312
1313
/**
1314
 * For use when doing 'stepped' upgrade routines, to see if we need to start somewhere in the middle
1315
 *
1316
 * @since 1.8
1317
 *
1318
 * @return mixed   When nothing to resume returns false, otherwise starts the upgrade where it left off
1319
 */
1320
function give_maybe_resume_upgrade() {
1321
	$doing_upgrade = get_option( 'give_doing_upgrade', false );
1322
	if ( empty( $doing_upgrade ) ) {
1323
		return false;
1324
	}
1325
1326
	return $doing_upgrade;
1327
}
1328
1329
/**
1330
 * Adds an upgrade action to the completed upgrades array
1331
 *
1332
 * @since  1.0
1333
 *
1334
 * @param  string $upgrade_action The action to add to the completed upgrades array
1335
 *
1336
 * @return bool                   If the function was successfully added
1337
 */
1338
function give_set_upgrade_complete( $upgrade_action = '' ) {
1339
1340
	if ( empty( $upgrade_action ) ) {
1341
		return false;
1342
	}
1343
1344
	$completed_upgrades   = give_get_completed_upgrades();
1345
	$completed_upgrades[] = $upgrade_action;
1346
1347
	// Remove any blanks, and only show uniques.
1348
	$completed_upgrades = array_unique( array_values( $completed_upgrades ) );
1349
1350
	/**
1351
	 * Fire the action when any upgrade set to complete.
1352
	 *
1353
	 * @since 1.8.12
1354
	 */
1355
	do_action( 'give_set_upgrade_completed', $upgrade_action, $completed_upgrades );
1356
1357
	return update_option( 'give_completed_upgrades', $completed_upgrades );
1358
}
1359
1360
/**
1361
 * Get's the array of completed upgrade actions
1362
 *
1363
 * @since  1.0
1364
 * @return array The array of completed upgrades
1365
 */
1366
function give_get_completed_upgrades() {
1367
	return (array) get_option( 'give_completed_upgrades' );
1368
}
1369
1370
/**
1371
 * Get attribute string
1372
 *
1373
 * @since 2.0
1374
 *
1375
 * @param array $attributes
1376
 *
1377
 * @return string
1378
 */
1379
function give_get_attribute_str( $attributes ) {
1380
	$attribute_str = '';
1381
1382
	if ( empty( $attributes ) ) {
1383
		return $attribute_str;
1384
	}
1385
1386
	foreach ( $attributes as $tag => $value ) {
1387
		$attribute_str .= " {$tag}=\"{$value}\"";
1388
	}
1389
1390
	return trim( $attribute_str );
1391
}
1392
1393
1394
/**
1395
 * In 2.0 we updated table for log, payment and form.
1396
 *
1397
 * Note: internal purpose only.
1398
 *
1399
 * @since 2.0
1400
 * @global wpdb  $wpdb
1401
 *
1402
 * @param string $type Context for table
1403
 *
1404
 * @return null|array
1405
 */
1406
function __give_v20_bc_table_details( $type ) {
1407
	global $wpdb;
1408
	$table = array();
1409
1410
	// Bailout.
1411
	if ( empty( $type ) ) {
1412
		return null;
1413
	}
1414
1415
	switch ( $type ) {
1416
		case 'form':
1417
			$table['name']         = $wpdb->formmeta;
1418
			$table['column']['id'] = 'form_id';
1419
1420
			break;
1421
1422
		case 'payment':
1423
			$table['name']         = $wpdb->paymentmeta;
1424
			$table['column']['id'] = 'payment_id';
1425
	}
1426
1427
	// Backward compatibility.
1428
	if ( ! give_has_upgrade_completed( 'v20_move_metadata_into_new_table' ) ) {
1429
		$table['name']         = $wpdb->postmeta;
1430
		$table['column']['id'] = 'post_id';
1431
	}
1432
0 ignored issues
show
Coding Style introduced by
Functions must not contain multiple empty lines in a row; found 2 empty lines
Loading history...
1433
1434
	return $table;
1435
}
1436
1437
/**
1438
 * Remove the Give transaction pages from WP search results.
1439
 *
1440
 * @since 1.8.13
1441
 *
1442
 * @param \WP_Query
1443
 *
1444
 */
1445
function give_remove_pages_from_search( $query ) {
1446
1447
	if ( ! $query->is_admin && $query->is_search && $query->is_main_query() ) {
1448
1449
		$transaction_failed = give_get_option( 'failure_page', 0 );
1450
		$success_page       = give_get_option( 'success_page', 0 );
1451
		$args               = apply_filters( 'give_remove_pages_from_search', array( $transaction_failed, $success_page ), $query );
1452
1453
		$query->set( 'post__not_in', $args );
1454
	}
1455
}
1456
1457
add_action( 'pre_get_posts', 'give_remove_pages_from_search', 10, 1 );
1458
1459
/**
1460
 * Inserts a new key/value before a key in the array.
1461
 *
1462
 * @since 1.8.13
1463
 *
1464
 * @param string       $key       The key to insert before.
1465
 * @param array        $array     An array to insert in to.
1466
 * @param string       $new_key   The key to insert.
1467
 * @param array|string $new_value An value to insert.
1468
 *
1469
 * @return array The new array if the key exists, the passed array otherwise.
1470
 *
1471
 * @see   array_insert_before()
1472
 */
1473 View Code Duplication
function give_array_insert_before( $key, array &$array, $new_key, $new_value ) {
0 ignored issues
show
Duplication introduced by
This function seems to be duplicated in 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...
1474
	if ( array_key_exists( $key, $array ) ) {
1475
		$new = array();
1476
		foreach ( $array as $k => $value ) {
1477
			if ( $k === $key ) {
1478
				$new[ $new_key ] = $new_value;
1479
			}
1480
			$new[ $k ] = $value;
1481
		}
1482
1483
		return $new;
1484
	}
1485
1486
	return $array;
1487
}
1488
1489
/**
1490
 * Inserts a new key/value after a key in the array.
1491
 *
1492
 * @since 1.8.13
1493
 *
1494
 * @param string       $key       The key to insert after.
1495
 * @param array        $array     An array to insert in to.
1496
 * @param string       $new_key   The key to insert.
1497
 * @param array|string $new_value An value to insert.
1498
 *
1499
 * @return array The new array if the key exists, the passed array otherwise.
1500
 *
1501
 * @see   array_insert_before()
1502
 */
1503 View Code Duplication
function give_array_insert_after( $key, array &$array, $new_key, $new_value ) {
0 ignored issues
show
Duplication introduced by
This function seems to be duplicated in 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...
1504
	if ( array_key_exists( $key, $array ) ) {
1505
		$new = array();
1506
		foreach ( $array as $k => $value ) {
1507
			$new[ $k ] = $value;
1508
			if ( $k === $key ) {
1509
				$new[ $new_key ] = $new_value;
1510
			}
1511
		}
1512
1513
		return $new;
1514
	}
1515
1516
	return $array;
1517
}
1518
1519
/**
1520
 * Pluck a certain field out of each object in a list.
1521
 *
1522
 * This has the same functionality and prototype of
1523
 * array_column() (PHP 5.5) but also supports objects.
1524
 *
1525
 * @since 1.8.13
1526
 *
1527
 * @param array $list List of objects or arrays
1528
 * @param int|string $field Field from the object to place instead of the entire object
1529
 * @param int|string $index_key Optional. Field from the object to use as keys for the new array.
1530
 *                              Default null.
1531
 *
1532
 * @return array Array of found values. If `$index_key` is set, an array of found values with keys
1533
 *               corresponding to `$index_key`. If `$index_key` is null, array keys from the original
1534
 *               `$list` will be preserved in the results.
1535
 */
1536
function give_list_pluck( $list, $field, $index_key = null ) {
1537
1538
	if ( ! $index_key ) {
1539
		/*
1540
		 * This is simple. Could at some point wrap array_column()
1541
		 * if we knew we had an array of arrays.
1542
		 */
1543
		foreach ( $list as $key => $value ) {
1544
			if ( is_object( $value ) ) {
1545
				if ( isset( $value->$field ) ) {
1546
					$list[ $key ] = $value->$field;
1547
				}
1548
			} else {
1549
				if ( isset( $value[ $field ] ) ) {
1550
					$list[ $key ] = $value[ $field ];
1551
				}
1552
			}
1553
		}
1554
1555
		return $list;
1556
	}
1557
1558
	/*
1559
	 * When index_key is not set for a particular item, push the value
1560
	 * to the end of the stack. This is how array_column() behaves.
1561
	 */
1562
	$newlist = array();
1563
	foreach ( $list as $value ) {
1564
		if ( is_object( $value ) ) {
1565
			if ( isset( $value->$index_key ) ) {
1566
				$newlist[ $value->$index_key ] = $value->$field;
1567
			} else {
1568
				$newlist[] = $value->$field;
1569
			}
1570
		} else {
1571
			if ( isset( $value[ $index_key ] ) ) {
1572
				$newlist[ $value[ $index_key ] ] = $value[ $field ];
1573
			} else {
1574
				$newlist[] = $value[ $field ];
1575
			}
1576
		}
1577
	}
1578
1579
	$list = $newlist;
1580
1581
	return $list;
1582
}
1583
1584
/**
1585
 * Add meta data field to a donor.
1586
 *
1587
 * @since 1.8.13
1588
 *
1589
 * @param int $donor_id Donor ID.
1590
 * @param string $meta_key Metadata name.
1591
 * @param mixed $meta_value Metadata value. Must be serializable if non-scalar.
1592
 * @param bool $unique Optional. Whether the same key should not be added.
1593
 *                           Default false.
1594
 *
1595
 * @return int|false Meta ID on success, false on failure.
1596
 */
1597
function add_donor_meta( $donor_id, $meta_key, $meta_value, $unique = false ) {
1598
	return add_metadata( 'give_customer', $donor_id, $meta_key, $meta_value, $unique );
1599
}
1600
1601
/**
1602
 * Remove metadata matching criteria from a Donor meta.
1603
 *
1604
 * You can match based on the key, or key and value. Removing based on key and
1605
 * value, will keep from removing duplicate metadata with the same key. It also
1606
 * allows removing all metadata matching key, if needed.
1607
 *
1608
 * @since 1.8.13
1609
 *
1610
 * @param int $donor_id Donor ID
1611
 * @param string $meta_key Metadata name.
1612
 * @param mixed $meta_value Optional. Metadata value.
1613
 *
1614
 * @return bool True on success, false on failure.
1615
 */
1616
function delete_donor_meta( $donor_id, $meta_key, $meta_value = '' ) {
1617
	return delete_metadata( 'give_customer', $donor_id, $meta_key, $meta_value );
1618
}
1619
1620
/**
1621
 * Retrieve donor meta field for a donor meta table.
1622
 *
1623
 * @since 1.8.13
1624
 *
1625
 * @param int $donor_id Donor ID.
1626
 * @param string $key Optional. The meta key to retrieve. By default, returns data for all keys.
1627
 * @param bool $single Whether to return a single value.
1628
 *
1629
 * @return mixed Will be an array if $single is false. Will be value of meta data field if $single
1630
 *  is true.
1631
 */
1632
function get_donor_meta( $donor_id, $key = '', $single = false ) {
1633
	return get_metadata( 'give_customer', $donor_id, $key, $single );
1634
}
1635
1636
/**
1637
 * Update customer meta field based on Donor ID.
1638
 *
1639
 * If the meta field for the donor does not exist, it will be added.
1640
 *
1641
 * @since 1.8.13
1642
 *
1643
 * @param int $donor_id Donor ID.
1644
 * @param string $meta_key Metadata key.
1645
 * @param mixed $meta_value Metadata value.
1646
 * @param mixed $prev_value Optional. Previous value to check before removing.
1647
 *
1648
 * @return int|bool Meta ID if the key didn't exist, true on successful update, false on failure.
1649
 */
1650
function update_donor_meta( $donor_id, $meta_key, $meta_value, $prev_value = '' ) {
1651
	return update_metadata( 'give_customer', $donor_id, $meta_key, $meta_value, $prev_value );
1652
}
1653
1654
1655
/**
1656
 * Give recalculate income and donation of the donation from ID
1657
 *
1658
 * @since 1.8.13
1659
 *
1660
 * @param int $form_id Form id of which recalculation needs to be done.
1661
 *
1662
 * @return void
1663
 */
1664
function give_recount_form_income_donation( $form_id = 0 ) {
1665
	// Check if form id is not empty.
1666
	if ( ! empty( $form_id ) ) {
1667
		/**
1668
		 * Filter to modify payment status.
1669
		 *
1670
		 * @since 1.8.13
1671
		 */
1672
		$accepted_statuses = apply_filters( 'give_recount_accepted_statuses', array( 'publish' ) );
1673
1674
		/**
1675
		 * Filter to modify args of payment query before recalculating the form total
1676
		 *
1677
		 * @since 1.8.13
1678
		 */
1679
		$args = apply_filters( 'give_recount_form_stats_args', array(
1680
			'give_forms'     => $form_id,
1681
			'status'         => $accepted_statuses,
1682
			'posts_per_page' => - 1,
1683
			'fields'         => 'ids',
1684
		) );
1685
1686
		$totals = array(
1687
			'sales'    => 0,
1688
			'earnings' => 0,
1689
		);
1690
1691
		$payments = new Give_Payments_Query( $args );
1692
		$payments = $payments->get_payments();
1693
1694
		if ( $payments ) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $payments of type array is implicitly converted to a boolean; are you sure this is intended? If so, consider using ! empty($expr) instead to make it clear that you intend to check for an array without elements.

This check marks implicit conversions of arrays to boolean values in a comparison. While in PHP an empty array is considered to be equal (but not identical) to false, this is not always apparent.

Consider making the comparison explicit by using empty(..) or ! empty(...) instead.

Loading history...
1695 View Code Duplication
			foreach ( $payments as $payment ) {
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...
1696
				//Ensure acceptible status only
1697
				if ( ! in_array( $payment->post_status, $accepted_statuses ) ) {
1698
					continue;
1699
				}
1700
1701
				//Ensure only payments for this form are counted
1702
				if ( $payment->form_id != $form_id ) {
1703
					continue;
1704
				}
1705
1706
				$totals['sales'] ++;
1707
				$totals['earnings'] += $payment->total;
1708
1709
			}
1710
		}
1711
		give_update_meta( $form_id, '_give_form_sales', $totals['sales'] );
1712
		give_update_meta( $form_id, '_give_form_earnings', give_sanitize_amount_for_db( $totals['earnings'] ) );
1713
	}
1714
}
1715
1716
/**
1717
 * Zero Decimal based Currency.
1718
 *
1719
 * @since 1.8.14
1720
 *
1721
 * @return bool
1722
 */
1723
function give_is_zero_based_currency() {
1724
	$zero_based_currency = array(
1725
		'PYG', // Paraguayan Guarani.
1726
		'GNF', // Guinean Franc.
1727
		'RWF', // Rwandan Franc.
1728
		'JPY', // Japanese Yen.
1729
		'BIF', // Burundian Franc.
1730
		'KRW', // South Korean Won.
1731
		'MGA', // Malagasy Ariary.
1732
		'XAF', // Central African Cfa Franc.
1733
		'XPF', // Cfp Franc.
1734
		'CLP', // Chilean Peso.
1735
		'KMF', // Comorian Franc.
1736
		'DJF', // Djiboutian Franc.
1737
		'VUV', // Vanuatu Vatu.
1738
		'VND', // Vietnamese Dong.
1739
		'XOF', // West African Cfa Franc.
1740
	);
1741
1742
	// Check for Zero Based Currency.
1743
	if ( in_array( give_get_currency(), $zero_based_currency ) ) {
1744
		return true;
1745
	}
1746
1747
	return false;
1748
}