Test Failed
Push — issues/2147 ( 1a2ebc...a725d4 )
by Ravinder
04:21
created

misc-functions.php ➔ give_get_current_page_url()   B

Complexity

Conditions 4
Paths 8

Size

Total Lines 28
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Importance

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