Test Failed
Push — issues/1944 ( ef3669...b2a977 )
by Ravinder
05:02
created

misc-functions.php ➔ give_get_attribute_str()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 13
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

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

This check marks PHPDoc comments that could not be parsed by our parser. To see which comment annotations we can parse, please refer to our documentation on supported doc-types.

Loading history...
1547
 */
1548
function give_get_core_settings_json( $file_name ) {
1549
	$upload_dir = give_get_wp_upload_dir();
1550
	$file_path  = $upload_dir . '/' . $file_name;
1551
1552
	if ( is_wp_error( $file_path ) || empty( $file_path ) ) {
1553
		Give_Admin_Settings::add_error( 'give-import-csv', __( 'Please upload or provide a valid JSON file.', 'give' ) );
1554
	}
1555
1556
	$file_contents = file_get_contents( $file_path );
0 ignored issues
show
introduced by
file_get_contents is highly discouraged, please use wpcom_vip_file_get_contents() instead.
Loading history...
1557
1558
	return $file_contents;
1559
}
1560