Test Failed
Push — issues/2147 ( f99407 )
by Ravinder
04:53
created

misc-functions.php ➔ give_currency_symbols()   B

Complexity

Conditions 2
Paths 2

Size

Total Lines 38
Code Lines 33

Duplication

Lines 0
Ratio 0 %

Importance

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