Test Failed
Push — master ( 25adfe...70178c )
by Devin
01:46
created

misc-functions.php ➔ give_is_cc_verify_enabled()   C

Complexity

Conditions 8
Paths 4

Size

Total Lines 27
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 72

Importance

Changes 0
Metric Value
cc 8
eloc 10
nc 4
nop 0
dl 0
loc 27
rs 5.3846
c 0
b 0
f 0
ccs 0
cts 11
cp 0
crap 72
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 52
26
	$ret = give_is_setting_enabled( give_get_option( 'test_mode' ) );
27 52
28
	return (bool) apply_filters( 'give_is_test_mode', $ret );
29 52
30
}
31
32
/**
33
 * Get the set currency
34
 *
35
 * @since 1.0
36
 * @return string The currency code
37
 */
38
function give_get_currency() {
39 55
40 55
	$currency = give_get_option( 'currency', 'USD' );
41
42 55
	return apply_filters( 'give_currency', $currency );
43
}
44
45
/**
46
 * Get the set currency position
47
 *
48
 * @since 1.3.6
49
 *
50
 * @return string The currency code
51
 */
52
function give_get_currency_position() {
53 1
54 1
	$currency_pos = give_get_option( 'currency_position', 'before' );
55
56 1
	return apply_filters( 'give_currency_position', $currency_pos );
57
}
58
59
60
/**
61
 * Get Currencies
62
 *
63
 * @since 1.0
64
 * @return array $currencies A list of the available currencies
65
 */
66
67
function give_get_currencies() {
68
	$currencies = array(
69
		'USD'  => __( '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
 * Get all currency symbols
107
 *
108
 * @since 1.8.14
109
 *
110
 * @param bool $decode_currencies
111
 *
112
 * @return array
113
 */
114
function give_currency_symbols( $decode_currencies = false ) {
115
	$currencies = array(
116
		'GBP'  => '&pound;',
117
		'BRL'  => '&#82;&#36;',
118 45
		'EUR'  => '&euro;',
119
		'NOK'  => '&#107;&#114;.',
120
		'INR'  => '&#8377;',
121
		'USD'  => '&#36;',
122 45
		'AUD'  => '&#36;',
123
		'CAD'  => '&#36;',
124
		'HKD'  => '&#36;',
125 45
		'MXN'  => '&#36;',
126
		'SGD'  => '&#36;',
127
		'JPY'  => '&yen;',
128 45
		'THB'  => '&#3647;',
129
		'TRY'  => '&#8378;',
130
		'TWD'  => '&#78;&#84;&#36;',
131 45
		'ILS'  => '&#8362;',
132
		'RIAL' => '&#xfdfc;',
133
		'RUB'  => '&#8381;',
134 45
		'DKK'  => '&nbsp;kr.&nbsp;',
135
		'SEK'  => '&nbsp;kr.&nbsp;',
136
		'PLN'  => '&#122;&#322;',
137 45
		'PHP'  => '&#8369;',
138 45
		'MYR'  => '&#82;&#77;',
139 45
		'HUF'  => '&#70;&#116;',
140 45
		'CZK'  => '&#75;&#269;',
141 45
		'KRW'  => '&#8361;',
142 45
		'ZAR'  => '&#82;',
143 45
		'MAD'  => '&#x2e;&#x62f;&#x2e;&#x645;',
144 45
	);
145
146
	if ( $decode_currencies ) {
147
		$currencies = array_map( 'html_entity_decode', $currencies );
148
	}
149
150
	/**
151
	 * Filter the currency symbols
152
	 *
153
	 * @since 1.8.14
154
	 *
155
	 * @param array $currencies
156
	 */
157
	return apply_filters( 'give_currency_symbols', $currencies );
158
}
159
160
161
/**
162
 * Give Currency Symbol
163
 *
164
 * Given a currency determine the symbol to use. If no currency given, site default is used. If no symbol is determine,
165
 * the currency string is returned.
166
 *
167
 * @since      1.0
168
 *
169
 * @param  string $currency        The currency string.
170
 * @param  bool   $decode_currency Option to HTML decode the currency symbol.
171
 *
172
 * @return string           The symbol to use for the currency
173
 */
174
function give_currency_symbol( $currency = '', $decode_currency = false ) {
175
176
	if ( empty( $currency ) ) {
177
		$currency = give_get_currency();
178
	}
179
180
	$currencies = give_currency_symbols( $decode_currency );
181
	$symbol     = array_key_exists( $currency, $currencies ) ? $currencies[ $currency ] : $currency;
182
183
	/**
184
	 * Filter the currency symbol
185
	 *
186
	 * @since 1.0
187
	 *
188
	 * @param string $symbol
189
	 * @param string $currency
190
	 */
191
	return apply_filters( 'give_currency_symbol', $symbol, $currency );
192
}
193
194
195
/**
196
 * Get currency name.
197
 *
198
 * @since 1.8.8
199
 *
200 45
 * @param string $currency_code
201
 *
202
 * @return string
203
 */
204
function give_get_currency_name( $currency_code ) {
205
	$currency_name  = '';
206
	$currency_names = give_get_currencies();
207
208
	if ( $currency_code && array_key_exists( $currency_code, $currency_names ) ) {
209
		$currency_name = explode( '(', $currency_names[ $currency_code ] );
210
		$currency_name = trim( current( $currency_name ) );
211
	}
212 6
213
	/**
214
	 * Filter the currency name
215 6
	 *
216
	 * @since 1.8.8
217
	 *
218 6
	 * @param string $currency_name
219
	 * @param string $currency_code
220
	 */
221
	return apply_filters( 'give_currency_name', $currency_name, $currency_code );
222
}
223
224
225
/**
226
 * Get the current page URL.
227
 *
228
 * @since 1.0
229
 * @return string $current_url Current page URL.
230
 */
231
function give_get_current_page_url() {
232
233
	global $wp;
234
235
	if ( get_option( 'permalink_structure' ) ) {
236
		$base = trailingslashit( home_url( $wp->request ) );
237
	} else {
238
		$base = add_query_arg( $wp->query_string, '', trailingslashit( home_url( $wp->request ) ) );
239
		$base = remove_query_arg( array( 'post_type', 'name' ), $base );
240
	}
241
242
	$scheme      = is_ssl() ? 'https' : 'http';
243
	$current_uri = set_url_scheme( $base, $scheme );
244
245
	if ( is_front_page() ) {
246
		$current_uri = home_url( '/' );
247
	}
248
249
	/**
250
	 * Filter the current page url
251
	 *
252
	 * @since 1.0
253
	 *
254
	 * @param string $current_uri
255
	 */
256
	return apply_filters( 'give_get_current_page_url', $current_uri );
257
258
}
259
260
261
/**
262
 * Verify credit card numbers live?
263
 *
264
 * @since 1.0
265
 *
266
 * @return bool $ret True is verify credit cards is live
267
 */
268
function give_is_cc_verify_enabled() {
269
270
	$ret = true;
271
272
	/**
273
	 * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards.
274
	 * Enable if using more than one gateway if they are not both PayPal and manual, again assuming credit card usage.
275
	 */
276
	$gateways = give_get_enabled_payment_gateways();
277
278
	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...
279
		$ret = true;
280
	} elseif ( count( $gateways ) == 1 ) {
0 ignored issues
show
introduced by
Found "== 1". Use Yoda Condition checks, you must
Loading history...
281
		$ret = false;
282
	} 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...
283
		$ret = false;
284
	}
285
286
	/**
287
	 * Fire the filter
288
	 *
289
	 * @since 1.0
290
	 *
291
	 * @param bool $ret
292
	 */
293
	return (bool) apply_filters( 'give_is_cc_verify_enabled', $ret );
294
}
295
296
/**
297
 * Retrieve timezone.
298
 *
299
 * @since 1.0
300 52
 * @return string $timezone The timezone ID.
301
 */
302 52
function give_get_timezone_id() {
303
304
	// if site timezone string exists, return it.
305 52
	if ( $timezone = get_option( 'timezone_string' ) ) {
306
		return $timezone;
307
	}
308 52
309 52
	// get UTC offset, if it isn't set return UTC.
310 52
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
311
		return 'UTC';
312 52
	}
313
314
	// attempt to guess the timezone string from the UTC offset.
315
	$timezone = timezone_name_from_abbr( '', $utc_offset );
316
317
	// last try, guess timezone string manually.
318
	if ( $timezone === false ) {
0 ignored issues
show
introduced by
Found "=== false". Use Yoda Condition checks, you must
Loading history...
319
320
		$is_dst = date( 'I' );
321
322
		foreach ( timezone_abbreviations_list() as $abbr ) {
323
			foreach ( $abbr as $city ) {
324
				if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) {
325
					return $city['timezone_id'];
326
				}
327
			}
328
		}
329
	}
330
331
	// Fallback.
332
	return 'UTC';
333
}
334
335
336
/**
337
 * Get User IP
338
 *
339
 * Returns the IP address of the current visitor
340
 *
341
 * @since 1.0
342
 * @return string $ip User's IP address
343
 */
344
function give_get_ip() {
345
346
	$ip = '127.0.0.1';
347
348
	if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
349
		// check ip from share internet
350
		$ip = $_SERVER['HTTP_CLIENT_IP'];
0 ignored issues
show
introduced by
Detected usage of a non-sanitized input variable: $_SERVER
Loading history...
351
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
352
		// to check ip is pass from proxy
353
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
0 ignored issues
show
introduced by
Detected usage of a non-sanitized input variable: $_SERVER
Loading history...
354
	} 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...
355
		$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...
356
	}
357
358
	return apply_filters( 'give_get_ip', $ip );
359
}
360
361
362
/**
363
 * Store Donation Data in Sessions
364
 *
365
 * Used for storing info about donation
366
 *
367
 * @since 1.0
368
 *
369
 * @param $purchase_data
370
 *
371
 * @uses  Give()->session->set()
372
 */
373
function give_set_purchase_session( $purchase_data = array() ) {
374
	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...
375
	Give()->session->set( 'give_email', $purchase_data['user_email'] );
376
}
377
378
/**
379
 * Retrieve Donation Data from Session
380
 *
381
 * Used for retrieving info about donation
382
 * after completing a donation
383
 *
384
 * @since 1.0
385
 * @uses  Give()->session->get()
386
 * @return mixed array | false
387
 */
388
function give_get_purchase_session() {
389
	return Give()->session->get( 'give_purchase' );
390
}
391
392
/**
393
 * Generate Item Title for Payment Gateway.
394
 *
395
 * @param array $payment_data Payment Data.
396
 *
397
 * @since 1.8.14
398
 *
399
 * @return string
400
 */
401
function give_payment_gateway_item_title( $payment_data ) {
402
	$form_id          = intval( $payment_data['post_data']['give-form-id'] );
403
	$item_name        = $payment_data['post_data']['give-form-title'];
404
	$is_custom_amount = give_is_setting_enabled( give_get_meta( $form_id, '_give_custom_amount', true ) );
405
406
	// Verify has variable prices.
407
	if ( give_has_variable_prices( $form_id ) && isset( $payment_data['post_data']['give-price-id'] ) ) {
408
409
		$item_price_level_text = give_get_price_option_name( $form_id, $payment_data['post_data']['give-price-id'] );
410
		$price_level_amount    = give_get_price_option_amount( $form_id, $payment_data['post_data']['give-price-id'] );
411
412
		// Donation given doesn't match selected level (must be a custom amount).
413
		if ( $price_level_amount !== 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
416
			// user custom amount text if any, fallback to default if not.
417
			$item_name .= ' - ' . give_check_variable( $custom_amount_text, 'empty', __( 'Custom Amount', 'give' ) );
418
419
		} elseif ( ! empty( $item_price_level_text ) ) {
420
			// Matches a donation level - append level text.
421
			$item_name .= ' - ' . $item_price_level_text;
422
		}
423
	} // End if().
424
	elseif ( $is_custom_amount && give_get_form_price( $form_id ) !== give_maybe_sanitize_amount( $payment_data['post_data']['give-amount'] ) ) {
425
		$custom_amount_text = give_get_meta( $form_id, '_give_custom_amount_text', true );
426
		// user custom amount text if any, fallback to default if not.
427
		$item_name .= ' - ' . give_check_variable( $custom_amount_text, 'empty', __( 'Custom Amount', 'give' ) );
428
	}
429
430
	/**
431
	 * Filter the Item Title of Payment Gateway.
432
	 *
433
	 * @param string $item_name    Item Title of Payment Gateway.
434
	 * @param int    $form_id      Donation Form ID.
435
	 * @param array  $payment_data Payment Data.
436
	 *
437
	 * @since 1.8.14
438
	 *
439
	 * @return string
440
	 */
441
	return apply_filters( 'give_payment_gateway_item_title', $item_name, $form_id, $payment_data );
442
}
443
444
/**
445
 * Get Donation Summary
446
 *
447
 * Creates a donation summary for payment gateways from the donation data before the payment is created in the database.
448
 *
449
 * @since       1.8.12
450
 *
451
 * @param array $donation_data
452
 * @param bool  $name_and_email
453
 * @param int   $length
454
 *
455
 * @return string
456
 */
457
function give_payment_gateway_donation_summary( $donation_data, $name_and_email = true, $length = 255 ) {
458
	$form_id = isset( $donation_data['post_data']['give-form-id'] ) ? $donation_data['post_data']['give-form-id'] : '';
459
460
	// Form title.
461
	$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' ) ) );
462
463
	// Form multilevel if applicable.
464
	if ( isset( $donation_data['post_data']['give-price-id'] ) ) {
465
		$summary .= ': ' . give_get_price_option_name( $form_id, $donation_data['post_data']['give-price-id'] );
466
	}
467
468
	// Add Donor's name + email if requested.
469
	if ( $name_and_email ) {
470
471
		// First name
472 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...
473
			$summary .= ' - ' . $donation_data['user_info']['first_name'];
474
		}
475
476 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...
477
			$summary .= ' ' . $donation_data['user_info']['last_name'];
478
		}
479
480
		$summary .= ' (' . $donation_data['user_email'] . ')';
481
	}
482
483
	// Cut the length
484
	$summary = substr( $summary, 0, $length );
485
486
	return apply_filters( 'give_payment_gateway_donation_summary', $summary );
487
}
488
489
490
/**
491
 * Get user host
492
 *
493
 * Returns the webhost this site is using if possible
494
 *
495
 * @since 1.0
496
 * @return string $host if detected, false otherwise
497
 */
498
function give_get_host() {
499
	$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...
500
501
	if ( defined( 'WPE_APIKEY' ) ) {
502
		$host = 'WP Engine';
503
	} elseif ( defined( 'PAGELYBIN' ) ) {
504
		$host = 'Pagely';
505
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
506
		$host = 'ICDSoft';
507
	} elseif ( DB_HOST == 'mysqlv5' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
508
		$host = 'NetworkSolutions';
509
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
510
		$host = 'iPage';
511
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
512
		$host = 'IPower';
513
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
514
		$host = 'MediaTemple Grid';
515
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
516 1
		$host = 'pair Networks';
517
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
518 1
		$host = 'Rackspace Cloud';
519
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
520
		$host = 'SysFix.eu Power Hosting';
521 1
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
522
		$host = 'Flywheel';
523
	} else {
524
		// Adding a general fallback for data gathering
525
		$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...
526
	}
527
528
	return $host;
529
}
530
531
532 1
/**
533
 * Check site host
534
 *
535
 * @since 1.0
536
 *
537
 * @param bool /string $host The host to check
538
 *
539
 * @return bool true if host matches, false if not
540
 */
541
function give_is_host( $host = false ) {
542
543
	$return = false;
544
545
	if ( $host ) {
546
		$host = str_replace( ' ', '', strtolower( $host ) );
547
548
		switch ( $host ) {
549
			case 'wpengine':
550
				if ( defined( 'WPE_APIKEY' ) ) {
551
					$return = true;
552
				}
553
				break;
554
			case 'pagely':
555
				if ( defined( 'PAGELYBIN' ) ) {
556
					$return = true;
557
				}
558
				break;
559
			case 'icdsoft':
560
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
561
					$return = true;
562
				}
563
				break;
564
			case 'networksolutions':
565
				if ( DB_HOST == 'mysqlv5' ) {
0 ignored issues
show
introduced by
Found "== '". Use Yoda Condition checks, you must
Loading history...
566
					$return = true;
567
				}
568
				break;
569
			case 'ipage':
570
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
571
					$return = true;
572
				}
573
				break;
574
			case 'ipower':
575
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
576
					$return = true;
577
				}
578
				break;
579
			case 'mediatemplegrid':
580
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
581
					$return = true;
582
				}
583
				break;
584
			case 'pairnetworks':
585
				if ( strpos( DB_HOST, '.pair.com' ) !== 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 'rackspacecloud':
590
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
591
					$return = true;
592
				}
593
				break;
594
			case 'sysfix.eu':
595
			case 'sysfix.eupowerhosting':
596
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
597
					$return = true;
598
				}
599
				break;
600
			case 'flywheel':
601
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
0 ignored issues
show
introduced by
Found "!== false". Use Yoda Condition checks, you must
Loading history...
602
					$return = true;
603
				}
604
				break;
605
			default:
606
				$return = false;
607
		}// End switch().
608
	}// End if().
609
610
	return $return;
611
}
612
613
/**
614
 * Marks a function as deprecated and informs when it has been used.
615
 *
616
 * There is a hook give_deprecated_function_run that will be called that can be used
617
 * to get the backtrace up to what file and function called the deprecated
618
 * function.
619
 *
620
 * The current behavior is to trigger a user error if WP_DEBUG is true.
621
 *
622
 * This function is to be used in every function that is deprecated.
623
 *
624
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
625
 *   and the version the function was deprecated in.
626
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
627
 *   trigger or false to not trigger error.
628
 *
629
 * @param string $function    The function that was called.
630
 * @param string $version     The plugin version that deprecated the function.
631
 * @param string $replacement Optional. The function that should have been called.
632
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
633
 */
634
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
635
636
	/**
637
	 * Fires while give deprecated function call occurs.
638
	 *
639
	 * Allow you to hook to deprecated function call.
640
	 *
641
	 * @since 1.0
642
	 *
643
	 * @param string $function    The function that was called.
644
	 * @param string $replacement Optional. The function that should have been called.
645
	 * @param string $version     The plugin version that deprecated the function.
646
	 */
647
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
648
649
	$show_errors = current_user_can( 'manage_options' );
650
651
	// Allow plugin to filter the output error trigger.
652
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
653
		if ( ! is_null( $replacement ) ) {
654
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
655
			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...
656
			// Alternatively we could dump this to a file.
657
		} else {
658
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
659
			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...
660
			// Alternatively we could dump this to a file.
661
		}
662
	}
663
}
664
665
/**
666
 * Give Get Admin ID
667
 *
668
 * Helper function to return the ID of the post for admin usage
669
 *
670
 * @return string $post_id
671
 */
672
function give_get_admin_post_id() {
673
	$post_id = isset( $_GET['post'] ) ? $_GET['post'] : null;
0 ignored issues
show
introduced by
Detected access of super global var $_GET, probably need manual inspection.
Loading history...
introduced by
Detected usage of a non-sanitized input variable: $_GET
Loading history...
674
	if ( ! $post_id && isset( $_POST['post_id'] ) ) {
675
		$post_id = $_POST['post_id'];
0 ignored issues
show
introduced by
Detected access of super global var $_POST, probably need manual inspection.
Loading history...
introduced by
Detected usage of a non-sanitized input variable: $_POST
Loading history...
676
	}
677
678
	return $post_id;
679
}
680
681
/**
682
 * Get PHP Arg Separator Output
683
 *
684
 * @since 1.0
685
 * @return string Arg separator output
686
 */
687
function give_get_php_arg_separator_output() {
688
	return ini_get( 'arg_separator.output' );
689
}
690
691
692
/**
693
 * Month Num To Name
694
 *
695
 * Takes a month number and returns the name three letter name of it.
696
 *
697
 * @since 1.0
698
 *
699
 * @param int $n
700
 *
701
 * @return string Short month name
702
 */
703
function give_month_num_to_name( $n ) {
704
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
705
706
	return date_i18n( 'M', $timestamp );
707
}
708
709
710
/**
711
 * Checks whether function is disabled.
712
 *
713
 * @since 1.0
714
 *
715
 * @param string $function Name of the function.
716
 *
717
 * @return bool Whether or not function is disabled.
718
 */
719
function give_is_func_disabled( $function ) {
720
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
721
722
	return in_array( $function, $disabled );
723
}
724
725
/**
726
 * Give Newsletter
727
 *
728
 * Returns the main Give newsletter form
729
 */
730
function give_get_newsletter() {
731
	?>
732
733
	<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>
734
735
	<div class="give-newsletter-form-wrap">
736
737
		<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13"
738
			  method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate"
739
			  target="_blank" novalidate>
740
			<div class="give-newsletter-confirmation">
741
				<p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
742
			</div>
743
744
			<table class="form-table give-newsletter-form">
745
				<tr valign="middle">
746
					<td>
747
						<label for="mce-EMAIL"
748
							   class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
749
						<input type="email" name="EMAIL" id="mce-EMAIL"
750
							   placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>"
751
							   class="required email" value="">
752
					</td>
753
					<td>
754
						<label for="mce-FNAME"
755
							   class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
756
						<input type="text" name="FNAME" id="mce-FNAME"
757
							   placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
758
					</td>
759
					<td>
760
						<label for="mce-LNAME"
761
							   class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
762
						<input type="text" name="LNAME" id="mce-LNAME"
763
							   placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
764
					</td>
765
					<td>
766
						<input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button"
767
							   value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
768
					</td>
769
				</tr>
770
			</table>
771
		</form>
772
773
		<div style="position: absolute; left: -5000px;">
774
			<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
775
		</div>
776
777
	</div>
778
779
	<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...
780
	<script type='text/javascript'>(function ($) {
781
			window.fnames = new Array();
782
			window.ftypes = new Array();
783
			fnames[0]     = 'EMAIL';
784
			ftypes[0]     = 'email';
785
			fnames[1]     = 'FNAME';
786
			ftypes[1]     = 'text';
787
			fnames[2]     = 'LNAME';
788
			ftypes[2]     = 'text';
789
790
			//Successful submission
791
			$('form[name="mc-embedded-subscribe-form"]').on('submit', function () {
792
793
				var email_field = $(this).find('#mce-EMAIL').val();
794
				if (!email_field) {
795
					return false;
796
				}
797
				$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp();
798
				$(this).find('.give-newsletter-form').hide();
799
800
			});
801
802
		}(jQuery));
803
		var $mcj = jQuery.noConflict(true);
804
805
806
	</script>
807
	<!--End mc_embed_signup-->
808
809
<?php
810
}
811
812
813
/**
814
 * Create SVG library function
815
 *
816
 * @param string $icon
817
 *
818
 * @return string
819
 */
820
function give_svg_icons( $icon ) {
821
822
	// Store your SVGs in an associative array
823
	$svgs = array(
824
		'microphone'    => '',
825
		'alert'         => '',
826
		'placemark'     => '',
827
		'give_grey'     => '',
828
		'give_cpt_icon' => '',
829
	);
830
831
	// Return the chosen icon's SVG string
832
	return $svgs[ $icon ];
833
}
834
835
/**
836
 * Modify Admin Nav Menu Label
837
 *
838
 * @since 1.3
839
 *
840
 * @param object $post_type The current object to add a menu items meta box for.
841
 *
842
 * @return mixed
843
 */
844
function modify_nav_menu_meta_box_object( $post_type ) {
845
	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...
846
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
847
	}
848
849
	return $post_type;
850
}
851
852
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
853
854
/**
855
 * Show Donation Forms Post Type in Appearance > Menus by default on fresh install.
856
 *
857
 * @since 1.8.14
858
 *
859
 * @todo  Remove this, when WordPress Core ticket is resolved (https://core.trac.wordpress.org/ticket/16828).
860
 *
861
 * @return bool
862
 */
863
function give_donation_metabox_menu() {
864
865
	// Get Current Screen.
866
	$screen = get_current_screen();
867
868
	// Proceed, if current screen is navigation menus.
869
	if (
870
		'nav-menus' === $screen->id &&
871
		give_is_setting_enabled( give_get_option( 'forms_singular' ) ) &&
872
		! get_user_option( 'give_is_donation_forms_menu_updated' )
873
	) {
874
875
		// Return false, if it fails to retrieve hidden meta box list and is not admin.
876
		if (
877
			! is_admin() ||
878
			( ! $hidden_meta_boxes = get_user_option( 'metaboxhidden_nav-menus' ) )
879
		) {
880
			return false;
881
		}
882
883
		// Return false, In case, we don't find 'Donation Form' in hidden meta box list.
884
		if ( ! in_array( 'add-post-type-give_forms', $hidden_meta_boxes, true ) ) {
885
			return false;
886
		}
887
888
		// Exclude 'Donation Form' value from hidden meta box's list.
889
		$hidden_meta_boxes = array_diff( $hidden_meta_boxes, array( 'add-post-type-give_forms' ) );
890
891
		// Get current user ID.
892
		$user = wp_get_current_user();
893
894
		update_user_option( $user->ID, 'metaboxhidden_nav-menus', $hidden_meta_boxes, true );
895
		update_user_option( $user->ID, 'give_is_donation_forms_menu_updated', true, true );
896
	}
897
}
898
899
add_action( 'current_screen', 'give_donation_metabox_menu' );
900
901
/**
902
 * Array_column backup usage
903
 *
904
 * This file is part of the array_column library.
905
 *
906
 * @since      : 1.3.0.1
907
 *
908
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
909
 * @license    https://opensource.org/licenses/MIT MIT
910
 */
911
912
if ( ! function_exists( 'array_column' ) ) {
913
	/**
914
	 * Returns the values from a single column of the input array, identified by
915
	 * the $columnKey.
916
	 *
917
	 * Optionally, you may provide an $indexKey to index the values in the returned
918
	 * array by the values from the $indexKey column in the input array.
919
	 *
920
	 * @param array      $input     A multi-dimensional array (record set) from which to pull
921
	 *                              a column of values.
922
	 * @param int|string $columnKey The column of values to return. This value may be the
923
	 *                              integer key of the column you wish to retrieve, or it
924
	 *                              may be the string key name for an associative array.
925
	 * @param mixed      $indexKey  (Optional.) The column to use as the index/keys for
926
	 *                              the returned array. This value may be the integer key
927
	 *                              of the column, or it may be the string key name.
928
	 *
929
	 * @return array
930
	 */
931
	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...
932
		// Using func_get_args() in order to check for proper number of
933
		// parameters and trigger errors exactly as the built-in array_column()
934
		// does in PHP 5.5.
935
		$argc   = func_num_args();
936
		$params = func_get_args();
937
938
		if ( $argc < 2 ) {
939
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
940
941
			return null;
942
		}
943
944
		if ( ! is_array( $params[0] ) ) {
945
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
946
947
			return null;
948
		}
949
950 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...
951
			 && ! is_float( $params[1] )
952
			 && ! is_string( $params[1] )
953
			 && $params[1] !== null
954
			 && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
955
		) {
956
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
957
958
			return false;
959
		}
960
961 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...
962
			 && ! is_int( $params[2] )
963
			 && ! is_float( $params[2] )
964
			 && ! is_string( $params[2] )
965
			 && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
966
		) {
967
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
968
969
			return false;
970
		}
971
972
		$paramsInput     = $params[0];
973
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
974
975
		$paramsIndexKey = null;
976
		if ( isset( $params[2] ) ) {
977
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
978
				$paramsIndexKey = (int) $params[2];
979
			} else {
980
				$paramsIndexKey = (string) $params[2];
981
			}
982
		}
983
984
		$resultArray = array();
985
986
		foreach ( $paramsInput as $row ) {
987
			$key    = $value = null;
988
			$keySet = $valueSet = false;
989
990
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
991
				$keySet = true;
992
				$key    = (string) $row[ $paramsIndexKey ];
993
			}
994
995
			if ( $paramsColumnKey === null ) {
996
				$valueSet = true;
997
				$value    = $row;
998
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
999
				$valueSet = true;
1000
				$value    = $row[ $paramsColumnKey ];
1001
			}
1002
1003
			if ( $valueSet ) {
1004
				if ( $keySet ) {
1005
					$resultArray[ $key ] = $value;
1006
				} else {
1007
					$resultArray[] = $value;
1008
				}
1009
			}
1010
		}
1011
1012
		return $resultArray;
1013
	}
1014
}// End if().
1015
1016
/**
1017
 * Determines the receipt visibility status.
1018
 *
1019
 * @since 1.3.2
1020
 *
1021
 * @param string $payment_key
1022
 *
1023
 * @return bool Whether the receipt is visible or not.
1024
 */
1025
function give_can_view_receipt( $payment_key = '' ) {
1026
1027
	$return = false;
1028
1029
	if ( empty( $payment_key ) ) {
1030
		return $return;
1031
	}
1032
1033
	global $give_receipt_args;
1034
1035
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
1036
1037
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
1038
1039
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
1040
1041
	if ( is_user_logged_in() ) {
1042
		if ( $user_id === (int) get_current_user_id() ) {
1043
			$return = true;
1044
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
1045
			$return = true;
1046
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
1047
			$return = true;
1048
		}
1049
	}
1050
1051
	$session = give_get_purchase_session();
1052
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
1053
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
1054
			$return = true;
1055
		}
1056
	}
1057
1058
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
1059
1060
}
1061
1062
/**
1063
 * Fallback for cal_days_in_month
1064
 *
1065
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
1066
 */
1067
if ( ! function_exists( 'cal_days_in_month' ) ) {
1068
	/**
1069
	 * cal_days_in_month
1070
	 *
1071
	 * @param int $calendar
1072
	 * @param int $month
1073
	 * @param int $year
1074
	 *
1075
	 * @return bool|string
1076
	 */
1077
	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...
1078
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
1079
	}
1080
}
1081
1082
/**
1083
 * Get plugin info including status, type, and license validation.
1084
 *
1085
 * This is an enhanced version of get_plugins() that returns the status
1086
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
1087
 * and license validation for Give add-ons (`true` or `false`). Does not include
1088
 * MU plugins.
1089
 *
1090
 * @since 1.8.0
1091
 *
1092
 * @return array Plugin info plus status, type, and license validation if
1093
 *               available.
1094
 */
1095
function give_get_plugins() {
1096
	$plugins             = get_plugins();
1097
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
1098
1099
	if ( is_multisite() ) {
1100
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
1101
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
1102
	}
1103
1104
	foreach ( $plugins as $plugin_path => $plugin_data ) {
1105
		// Is plugin active?
1106
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
1107
			$plugins[ $plugin_path ]['Status'] = 'active';
1108
		} else {
1109
			$plugins[ $plugin_path ]['Status'] = 'inactive';
1110
		}
1111
1112
		$dirname = strtolower( dirname( $plugin_path ) );
1113
1114
		// Is plugin a Give add-on by WordImpress?
1115
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
1116
			// Plugin is a Give-addon.
1117
			$plugins[ $plugin_path ]['Type'] = 'add-on';
1118
1119
			// Get license info from database.
1120
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
1121
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
1122
			$license_active = get_option( $db_option );
1123
1124
			// Does a valid license exist?
1125
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
1126
				$plugins[ $plugin_path ]['License'] = true;
1127
			} else {
1128
				$plugins[ $plugin_path ]['License'] = false;
1129
			}
1130
		} else {
1131
			// Plugin is not a Give add-on.
1132
			$plugins[ $plugin_path ]['Type'] = 'other';
1133
		}
1134
	}
1135
1136
	return $plugins;
1137
}
1138
1139
1140
/**
1141
 * Check if terms enabled or not for form.
1142
 *
1143
 * @since 1.8
1144
 *
1145
 * @param $form_id
1146
 *
1147
 * @return bool
1148
 */
1149
function give_is_terms_enabled( $form_id ) {
1150
	$form_option = give_get_meta( $form_id, '_give_terms_option', true );
1151
1152
	if (
1153
		give_is_setting_enabled( $form_option, 'global' )
1154
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1155
	) {
1156
		return true;
1157
1158
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1159
		return true;
1160
1161
	} else {
1162
		return false;
1163
	}
1164
}
1165
1166
1167
/**
1168
 * Delete donation stats cache.
1169
 *
1170
 * @todo  Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key.
1171
 *
1172
 * @since 1.8.7
1173
 *
1174
 * @param string|array $date_range Date for stats.
1175
 *                                 Date value should be in today, yesterday, this_week, last_week, this_month, last_month, this_quarter, last_quarter, this_year, last_year.
1176
 *                                 For date value other, all cache will be removed.
1177
 *
1178
 * @param array        $args
1179
 *
1180
 * @return WP_Error|bool
1181
 */
1182
function give_delete_donation_stats( $date_range = '', $args = array() ) {
1183
	// Delete all cache.
1184
	$status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) );
1185
1186
	/**
1187
	 * Fire the action when donation stats delete.
1188
	 *
1189
	 * @since 1.8.7
1190
	 *
1191
	 * @param string|array $date_range
1192
	 * @param array        $args
1193
	 */
1194
	do_action( 'give_delete_donation_stats', $status, $date_range, $args );
1195
1196
	return $status;
1197
}
1198
1199
1200
/**
1201
 * Get Form/Payment meta.
1202
 *
1203
 * @since 1.8.8
1204
 *
1205
 * @param int    $id
1206
 * @param string $meta_key
1207
 * @param bool   $single
1208
 * @param bool   $default
1209
 *
1210
 * @return mixed
1211
 */
1212
function give_get_meta( $id, $meta_key, $single = false, $default = false ) {
1213
	/**
1214
	 * Filter the meta value
1215
	 *
1216
	 * @since 1.8.8
1217
	 */
1218
	$meta_value = apply_filters(
1219
		'give_get_meta',
1220
		get_post_meta( $id, $meta_key, $single ),
1221
		$id,
1222
		$meta_key,
1223
		$default
1224
	);
1225
1226
	if (
1227
		( empty( $meta_key ) || empty( $meta_value ) )
1228
		&& $default
1229
	) {
1230
		$meta_value = $default;
1231
	}
1232
1233
	return $meta_value;
1234
}
1235
1236
/**
1237
 * Update Form/Payment meta.
1238
 *
1239
 * @since 1.8.8
1240
 *
1241
 * @param int    $id
1242
 * @param string $meta_key
1243
 * @param string $meta_value
1244
 * @param string $prev_value
1245
 *
1246
 * @return mixed
1247
 */
1248
function give_update_meta( $id, $meta_key, $meta_value, $prev_value = '' ) {
1249
	$status = update_post_meta( $id, $meta_key, $meta_value, $prev_value );
1250
1251
	/**
1252
	 * Filter the meta value update status
1253
	 *
1254
	 * @since 1.8.8
1255
	 */
1256
	return apply_filters( 'give_update_meta', $status, $id, $meta_key, $meta_value );
1257
}
1258
1259
/**
1260
 * Delete Form/Payment meta.
1261
 *
1262
 * @since 1.8.8
1263
 *
1264
 * @param int    $id
1265
 * @param string $meta_key
1266
 * @param string $meta_value
1267
 *
1268
 * @return mixed
1269
 */
1270
function give_delete_meta( $id, $meta_key, $meta_value = '' ) {
1271
	$status = delete_post_meta( $id, $meta_key, $meta_value );
1272
1273
	/**
1274
	 * Filter the meta value delete status
1275
	 *
1276
	 * @since 1.8.8
1277
	 */
1278
	return apply_filters( 'give_delete_meta', $status, $id, $meta_key, $meta_value );
1279
}
1280
1281
/**
1282
 * Check if the upgrade routine has been run for a specific action
1283
 *
1284
 * @since  1.0
1285
 *
1286
 * @param  string $upgrade_action The upgrade action to check completion for
1287
 *
1288
 * @return bool                   If the action has been added to the completed actions array
1289
 */
1290
function give_has_upgrade_completed( $upgrade_action = '' ) {
1291
1292
	if ( empty( $upgrade_action ) ) {
1293
		return false;
1294
	}
1295
1296
	$completed_upgrades = give_get_completed_upgrades();
1297
1298
	return in_array( $upgrade_action, $completed_upgrades );
1299
1300
}
1301
1302
/**
1303
 * For use when doing 'stepped' upgrade routines, to see if we need to start somewhere in the middle
1304
 *
1305
 * @since 1.8
1306
 *
1307
 * @return mixed   When nothing to resume returns false, otherwise starts the upgrade where it left off
1308
 */
1309
function give_maybe_resume_upgrade() {
1310
	$doing_upgrade = get_option( 'give_doing_upgrade', false );
1311
	if ( empty( $doing_upgrade ) ) {
1312
		return false;
1313
	}
1314
1315
	return $doing_upgrade;
1316
}
1317
1318
/**
1319
 * Adds an upgrade action to the completed upgrades array
1320
 *
1321
 * @since  1.0
1322
 *
1323
 * @param  string $upgrade_action The action to add to the completed upgrades array
1324
 *
1325
 * @return bool                   If the function was successfully added
1326
 */
1327
function give_set_upgrade_complete( $upgrade_action = '' ) {
1328
1329
	if ( empty( $upgrade_action ) ) {
1330
		return false;
1331
	}
1332
1333
	$completed_upgrades   = give_get_completed_upgrades();
1334
	$completed_upgrades[] = $upgrade_action;
1335
1336
	// Remove any blanks, and only show uniques.
1337
	$completed_upgrades = array_unique( array_values( $completed_upgrades ) );
1338
1339
	/**
1340
	 * Fire the action when any upgrade set to complete.
1341
	 *
1342
	 * @since 1.8.12
1343
	 */
1344
	do_action( 'give_set_upgrade_completed', $upgrade_action, $completed_upgrades );
1345
1346
	return update_option( 'give_completed_upgrades', $completed_upgrades );
1347
}
1348
1349
/**
1350
 * Get's the array of completed upgrade actions
1351
 *
1352
 * @since  1.0
1353
 * @return array The array of completed upgrades
1354
 */
1355
function give_get_completed_upgrades() {
1356
	return (array) get_option( 'give_completed_upgrades' );
1357
}
1358
1359
/**
1360
 * Remove the Give transaction pages from WP search results.
1361
 *
1362
 * @since 1.8.13
1363
 *
1364
 * @param \WP_Query
1365
 */
1366
function give_remove_pages_from_search( $query ) {
1367
	if ( ! $query->is_admin && $query->is_search && $query->is_main_query() ) {
1368
		$transaction_failed = give_get_option( 'failure_page', 0 );
1369
		$success_page       = give_get_option( 'success_page', 0 );
1370
		$args               = apply_filters(
1371
			'give_remove_pages_from_search', array(
1372
				$transaction_failed,
1373
				$success_page,
1374
			), $query
1375
		);
1376
		$query->set( 'post__not_in', $args );
1377
	}
1378
}
1379
1380
add_action( 'pre_get_posts', 'give_remove_pages_from_search', 10, 1 );
1381
1382
/**
1383
 * Inserts a new key/value before a key in the array.
1384
 *
1385
 * @since 1.8.13
1386
 *
1387
 * @param string       $key       The key to insert before.
1388
 * @param array        $array     An array to insert in to.
1389
 * @param string       $new_key   The key to insert.
1390
 * @param array|string $new_value An value to insert.
1391
 *
1392
 * @return array The new array if the key exists, the passed array otherwise.
1393
 *
1394
 * @see   array_insert_before()
1395
 */
1396 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...
1397
	if ( array_key_exists( $key, $array ) ) {
1398
		$new = array();
1399
		foreach ( $array as $k => $value ) {
1400
			if ( $k === $key ) {
1401
				$new[ $new_key ] = $new_value;
1402
			}
1403
			$new[ $k ] = $value;
1404
		}
1405
1406
		return $new;
1407
	}
1408
1409
	return $array;
1410
}
1411
1412
/**
1413
 * Inserts a new key/value after a key in the array.
1414
 *
1415
 * @since 1.8.13
1416
 *
1417
 * @param string       $key       The key to insert after.
1418
 * @param array        $array     An array to insert in to.
1419
 * @param string       $new_key   The key to insert.
1420
 * @param array|string $new_value An value to insert.
1421
 *
1422
 * @return array The new array if the key exists, the passed array otherwise.
1423
 *
1424
 * @see   array_insert_before()
1425
 */
1426 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...
1427
	if ( array_key_exists( $key, $array ) ) {
1428
		$new = array();
1429
		foreach ( $array as $k => $value ) {
1430
			$new[ $k ] = $value;
1431
			if ( $k === $key ) {
1432
				$new[ $new_key ] = $new_value;
1433
			}
1434
		}
1435
1436
		return $new;
1437
	}
1438
1439
	return $array;
1440
}
1441
1442
/**
1443
 * Pluck a certain field out of each object in a list.
1444
 *
1445
 * This has the same functionality and prototype of
1446
 * array_column() (PHP 5.5) but also supports objects.
1447
 *
1448
 * @since 1.8.13
1449
 *
1450
 * @param array      $list      List of objects or arrays
1451
 * @param int|string $field     Field from the object to place instead of the entire object
1452
 * @param int|string $index_key Optional. Field from the object to use as keys for the new array.
1453
 *                              Default null.
1454
 *
1455
 * @return array Array of found values. If `$index_key` is set, an array of found values with keys
1456
 *               corresponding to `$index_key`. If `$index_key` is null, array keys from the original
1457
 *               `$list` will be preserved in the results.
1458
 */
1459
function give_list_pluck( $list, $field, $index_key = null ) {
1460
1461
	if ( ! $index_key ) {
1462
		/*
1463
		 * This is simple. Could at some point wrap array_column()
1464
		 * if we knew we had an array of arrays.
1465
		 */
1466
		foreach ( $list as $key => $value ) {
1467
			if ( is_object( $value ) ) {
1468
				if ( isset( $value->$field ) ) {
1469
					$list[ $key ] = $value->$field;
1470
				}
1471
			} else {
1472
				if ( isset( $value[ $field ] ) ) {
1473
					$list[ $key ] = $value[ $field ];
1474
				}
1475
			}
1476
		}
1477
1478
		return $list;
1479
	}
1480
1481
	/*
1482
	 * When index_key is not set for a particular item, push the value
1483
	 * to the end of the stack. This is how array_column() behaves.
1484
	 */
1485
	$newlist = array();
1486
	foreach ( $list as $value ) {
1487
		if ( is_object( $value ) ) {
1488
			if ( isset( $value->$index_key ) ) {
1489
				$newlist[ $value->$index_key ] = $value->$field;
1490
			} else {
1491
				$newlist[] = $value->$field;
1492
			}
1493
		} else {
1494
			if ( isset( $value[ $index_key ] ) ) {
1495
				$newlist[ $value[ $index_key ] ] = $value[ $field ];
1496
			} else {
1497
				$newlist[] = $value[ $field ];
1498
			}
1499
		}
1500
	}
1501
1502
	$list = $newlist;
1503
1504
	return $list;
1505
}
1506
1507
/**
1508
 * Add meta data field to a donor.
1509
 *
1510
 * @since 1.8.13
1511
 *
1512
 * @param int    $donor_id   Donor ID.
1513
 * @param string $meta_key   Metadata name.
1514
 * @param mixed  $meta_value Metadata value. Must be serializable if non-scalar.
1515
 * @param bool   $unique     Optional. Whether the same key should not be added.
1516
 *                           Default false.
1517
 *
1518
 * @return int|false Meta ID on success, false on failure.
1519
 */
1520
function add_donor_meta( $donor_id, $meta_key, $meta_value, $unique = false ) {
1521
	return add_metadata( 'give_customer', $donor_id, $meta_key, $meta_value, $unique );
1522
}
1523
1524
/**
1525
 * Remove metadata matching criteria from a Donor meta.
1526
 *
1527
 * You can match based on the key, or key and value. Removing based on key and
1528
 * value, will keep from removing duplicate metadata with the same key. It also
1529
 * allows removing all metadata matching key, if needed.
1530
 *
1531
 * @since 1.8.13
1532
 *
1533
 * @param int    $donor_id   Donor ID
1534
 * @param string $meta_key   Metadata name.
1535
 * @param mixed  $meta_value Optional. Metadata value.
1536
 *
1537
 * @return bool True on success, false on failure.
1538
 */
1539
function delete_donor_meta( $donor_id, $meta_key, $meta_value = '' ) {
1540
	return delete_metadata( 'give_customer', $donor_id, $meta_key, $meta_value );
1541
}
1542
1543
/**
1544
 * Retrieve donor meta field for a donor meta table.
1545
 *
1546
 * @since 1.8.13
1547
 *
1548
 * @param int    $donor_id Donor ID.
1549
 * @param string $key      Optional. The meta key to retrieve. By default, returns data for all keys.
1550
 * @param bool   $single   Whether to return a single value.
1551
 *
1552
 * @return mixed Will be an array if $single is false. Will be value of meta data field if $single
1553
 *  is true.
1554
 */
1555
function get_donor_meta( $donor_id, $key = '', $single = false ) {
1556
	return get_metadata( 'give_customer', $donor_id, $key, $single );
1557
}
1558
1559
/**
1560
 * Update customer meta field based on Donor ID.
1561
 *
1562
 * If the meta field for the donor does not exist, it will be added.
1563
 *
1564
 * @since 1.8.13
1565
 *
1566
 * @param int    $donor_id   Donor ID.
1567
 * @param string $meta_key   Metadata key.
1568
 * @param mixed  $meta_value Metadata value.
1569
 * @param mixed  $prev_value Optional. Previous value to check before removing.
1570
 *
1571
 * @return int|bool Meta ID if the key didn't exist, true on successful update, false on failure.
1572
 */
1573
function update_donor_meta( $donor_id, $meta_key, $meta_value, $prev_value = '' ) {
1574
	return update_metadata( 'give_customer', $donor_id, $meta_key, $meta_value, $prev_value );
1575
}
1576
1577
/*
1578
 * Give recalculate income and donation of the donation from ID
1579
 *
1580
 * @since 1.8.13
1581
 *
1582
 * @param int $form_id Form id of which recalculation needs to be done.
1583
 */
1584
function give_recount_form_income_donation( $form_id = false ) {
1585
	// Check if form id is not empty.
1586
	if ( ! empty( $form_id ) ) {
1587
		/**
1588
		 * Filter to modify payment status.
1589
		 *
1590
		 * @since 1.8.13
1591
		 */
1592
		$accepted_statuses = apply_filters( 'give_recount_accepted_statuses', array( 'publish' ) );
1593
1594
		/**
1595
		 * Filter to modify args of payment query before recalculating the form total
1596
		 *
1597
		 * @since 1.8.13
1598
		 */
1599
		$args = apply_filters(
1600
			'give_recount_form_stats_args', array(
1601
				'give_forms'     => $form_id,
1602
				'status'         => $accepted_statuses,
1603
				'posts_per_page' => - 1,
1604
				'fields'         => 'ids',
1605
			)
1606
		);
1607
1608
		$totals = array(
1609
			'sales'    => 0,
1610
			'earnings' => 0,
1611
		);
1612
1613
		$payments = new Give_Payments_Query( $args );
1614
		$payments = $payments->get_payments();
1615
1616
		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...
1617 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...
1618
				// Ensure acceptible status only
1619
				if ( ! in_array( $payment->post_status, $accepted_statuses ) ) {
1620
					continue;
1621
				}
1622
1623
				// Ensure only payments for this form are counted
1624
				if ( $payment->form_id != $form_id ) {
1625
					continue;
1626
				}
1627
1628
				$totals['sales'] ++;
1629
				$totals['earnings'] += $payment->total;
1630
1631
			}
1632
		}
1633
		give_update_meta( $form_id, '_give_form_sales', $totals['sales'] );
1634
		give_update_meta( $form_id, '_give_form_earnings', give_sanitize_amount_for_db( $totals['earnings'] ) );
1635
	}// End if().
1636
}
1637
1638
/**
1639
 * Zero Decimal based Currency.
1640
 *
1641
 * @since 1.8.14
1642
 *
1643
 * @return bool
1644
 */
1645
function give_is_zero_based_currency() {
1646
	$zero_based_currency = array(
1647
		'PYG', // Paraguayan Guarani.
1648
		'GNF', // Guinean Franc.
1649
		'RWF', // Rwandan Franc.
1650
		'JPY', // Japanese Yen.
1651
		'BIF', // Burundian Franc.
1652
		'KRW', // South Korean Won.
1653
		'MGA', // Malagasy Ariary.
1654
		'XAF', // Central African Cfa Franc.
1655
		'XPF', // Cfp Franc.
1656
		'CLP', // Chilean Peso.
1657
		'KMF', // Comorian Franc.
1658
		'DJF', // Djiboutian Franc.
1659
		'VUV', // Vanuatu Vatu.
1660
		'VND', // Vietnamese Dong.
1661
		'XOF', // West African Cfa Franc.
1662
	);
1663
1664
	// Check for Zero Based Currency.
1665
	if ( in_array( give_get_currency(), $zero_based_currency ) ) {
1666
		return true;
1667
	}
1668
1669
	return false;
1670
}
1671