Server IP : 66.29.132.124 / Your IP : 18.222.182.195 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/tacafoundation.org/wp-content/plugins/give/includes/ |
Upload File : |
<?php /** * Misc Functions * * @package Give * @subpackage Functions * @copyright Copyright (c) 2016, GiveWP * @license https://opensource.org/licenses/gpl-license GNU Public License * @since 1.0 */ use Give\DonationForms\AsyncData\AsyncDataHelpers; use Give\License\PremiumAddonsListManager; // Exit if accessed directly. if ( ! defined( 'ABSPATH' ) ) { exit; } /** * Is Test Mode Enabled. * * @return bool $ret True if return mode is enabled, false otherwise * @since 1.0 */ function give_is_test_mode() { $ret = give_is_setting_enabled( give_get_option( 'test_mode' ) ); return (bool) apply_filters( 'give_is_test_mode', $ret ); } /** * Get the current page URL. * * @return string $current_url Current page URL. * @since 1.0 */ function give_get_current_page_url() { global $wp; if ( get_option( 'permalink_structure' ) ) { $base = trailingslashit( home_url( $wp->request ) ); } else { $base = add_query_arg( $wp->query_string, '', trailingslashit( home_url( $wp->request ) ) ); $base = remove_query_arg( [ 'post_type', 'name' ], $base ); } $scheme = is_ssl() ? 'https' : 'http'; $current_uri = set_url_scheme( $base, $scheme ); if ( is_front_page() ) { $current_uri = home_url( '/' ); } /** * Filter the current page url * * @param string $current_uri * * @since 1.0 */ return esc_url_raw( apply_filters( 'give_get_current_page_url', $current_uri ) ); } /** * Verify credit card numbers live? * * @return bool $ret True is verify credit cards is live * @since 1.0 */ function give_is_cc_verify_enabled() { $ret = true; /** * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards. * Enable if using more than one gateway if they are not both PayPal and manual, again assuming credit card usage. */ $gateways = give_get_enabled_payment_gateways(); if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) { $ret = true; } elseif ( count( $gateways ) == 1 ) { $ret = false; } elseif ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) { $ret = false; } /** * Fire the filter * * @param bool $ret * * @since 1.0 */ return (bool) apply_filters( 'give_is_cc_verify_enabled', $ret ); } /** * Retrieve timezone. * * @return string $timezone The timezone ID. * @since 1.0 */ function give_get_timezone_id() { // if site timezone string exists, return it. if ( $timezone = get_option( 'timezone_string' ) ) { return $timezone; } // get UTC offset, if it isn't set return UTC. if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) { return 'UTC'; } // attempt to guess the timezone string from the UTC offset. $timezone = timezone_name_from_abbr( '', $utc_offset ); // last try, guess timezone string manually. if ( $timezone === false ) { $is_dst = date( 'I' ); foreach ( timezone_abbreviations_list() as $abbr ) { foreach ( $abbr as $city ) { if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) { return $city['timezone_id']; } } } } // Fallback. return 'UTC'; } /** * Get User IP * * Returns the IP address of the current visitor * * @since 2.33.5 Add $single param. * @since 1.0 * * @return string $ip User's IP address */ function give_get_ip($single = true) { $ip_addresses = '127.0.0.1'; $header_type = ''; if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) { // check ip from share internet $ip_addresses = $_SERVER['HTTP_CLIENT_IP']; $header_type = 'HTTP_CLIENT_IP'; } elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) { // to check ip is pass from proxy $ip_addresses = $_SERVER['HTTP_X_FORWARDED_FOR']; $header_type = 'HTTP_X_FORWARDED_FOR'; } elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) { $ip_addresses = $_SERVER['REMOTE_ADDR']; $header_type = 'REMOTE_ADDR'; } /** * Filter the IP * * @since 2.33.5 Add $single and $header_type params. * @since 1.0 */ $ip_addresses = apply_filters('give_get_ip', $ip_addresses, $single, $header_type); // Filter empty values. if (false !== strpos($ip_addresses, ',')) { $ip_addresses = give_clean(explode(',', $ip_addresses)); $ip_addresses = array_filter($ip_addresses); $ip_addresses = implode(',', $ip_addresses); } else { $ip_addresses = give_clean($ip_addresses); } if ($single && false !== strpos($ip_addresses, ',')) { return explode(',', $ip_addresses)[0]; } return $ip_addresses; } /** * Store Donation Data in Sessions * * Used for storing info about donation * * @param $purchase_data * * @since 1.0 * * @uses Give()->session->set() */ function give_set_purchase_session( $purchase_data = [] ) { Give()->session->set( 'give_purchase', $purchase_data ); Give()->session->set( 'give_email', $purchase_data['user_email'] ); } /** * Retrieve Donation Data from Session * * Used for retrieving info about donation * after completing a donation * * @return mixed array | false * @uses Give()->session->get() * @since 1.0 */ function give_get_purchase_session() { return Give()->session->get( 'give_purchase' ); } /** * Retrieve Payment Key of the Receipt Access Session. * * @return array|string * @since 1.8.17 */ function give_get_receipt_session() { return Give()->session->get( 'receipt_access' ); } /** * Retrieve Payment Key of the History Access Session. * * @return array|string * @since 1.8.17 */ function give_get_history_session() { return (bool) Give()->session->get( 'history_access' ); } /** * Generate Item Title for Payment Gateway. * * @since 1.8.14 * @since 2.9.6 Function will return form title with selected form level if price id set to zero. Added second param to return result with requested character length. * * @param array $payment_data Payment Data. * * @param string|null $length * * @return string By default, the name of the form. Then the price level text if any is found. */ function give_payment_gateway_item_title( $payment_data, $length = null ) { $form_id = intval( $payment_data['post_data']['give-form-id'] ); $item_name = isset( $payment_data['post_data']['give-form-title'] ) ? $payment_data['post_data']['give-form-title'] : ''; $price_id = isset( $payment_data['post_data']['give-price-id'] ) ? $payment_data['post_data']['give-price-id'] : ''; // Verify has variable prices. if ( give_has_variable_prices( $form_id ) ) { $item_price_level_text = give_get_price_option_name( $form_id, $price_id, 0, false ); /** * Output donation level text if: * * 1. It's not a custom amount * 2. The level field has actual text and isn't the amount (which is already displayed on the receipt). */ if ( 'custom' !== $price_id && ! empty( $item_price_level_text ) ) { // Matches a donation level - append level text. $item_name .= ' - ' . $item_price_level_text; } } /** * Filter the Item Title of Payment Gateway. * * @param string $item_name Item Title of Payment Gateway. * @param int $form_id Donation Form ID. * @param array $payment_data Payment Data. * * @return string * @since 1.8.14 */ $item_name = apply_filters( 'give_payment_gateway_item_title', $item_name, $form_id, $payment_data ); // Cut the length if ( $length ) { $item_name = substr( $item_name, 0, $length ); } return $item_name; } /** * Get Donation Summary * * Creates a donation summary for payment gateways from the donation data before the payment is created in the database. * * @param array $donation_data * @param bool $name_and_email * @param int $length * * @return string * @since 1.8.12 */ function give_payment_gateway_donation_summary( $donation_data, $name_and_email = true, $length = 255 ) { $form_id = isset( $donation_data['post_data']['give-form-id'] ) ? $donation_data['post_data']['give-form-id'] : ''; $price_id = isset( $donation_data['post_data']['give-price-id'] ) ? $donation_data['post_data']['give-price-id'] : ''; // Form title. $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' ) ) ); // Form multilevel if applicable. if ( ! empty( $price_id ) && 'custom' !== $price_id ) { $summary .= ': ' . give_get_price_option_name( $form_id, $donation_data['post_data']['give-price-id'] ); } // Add Donor's name + email if requested. if ( $name_and_email ) { // First name if ( isset( $donation_data['user_info']['first_name'] ) && ! empty( $donation_data['user_info']['first_name'] ) ) { $summary .= ' - ' . $donation_data['user_info']['first_name']; } if ( isset( $donation_data['user_info']['last_name'] ) && ! empty( $donation_data['user_info']['last_name'] ) ) { $summary .= ' ' . $donation_data['user_info']['last_name']; } $summary .= ' (' . $donation_data['user_email'] . ')'; } // Cut the length $summary = substr( $summary, 0, $length ); return apply_filters( 'give_payment_gateway_donation_summary', $summary ); } /** * Get user host * * Returns the webhost this site is using if possible * * @return string $host if detected, false otherwise * @since 1.0 */ function give_get_host() { $find_host = gethostname(); if ( strpos( $find_host, 'sgvps.net' ) ) { $host = 'Siteground'; } elseif ( defined( 'WPE_APIKEY' ) ) { $host = 'WP Engine'; } elseif ( defined( 'PAGELYBIN' ) || strpos( $find_host, 'pagelyhosting.com' ) ) { $host = 'Pagely'; } elseif ( strpos( $find_host, 'secureserver.net' ) ) { $host = 'GoDaddy/Media Temple'; } elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) { $host = 'ICDSoft'; } elseif ( DB_HOST == 'mysqlv5' ) { $host = 'NetworkSolutions'; } elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) { $host = 'iPage'; } elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) { $host = 'IPower'; } elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) { $host = 'MediaTemple Grid'; } elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) { $host = 'pair Networks'; } elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) { $host = 'Rackspace Cloud'; } elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) { $host = 'SysFix.eu Power Hosting'; } elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false || strpos( $find_host, 'fw' ) ) { $host = 'Flywheel'; } else { // Adding a general fallback for data gathering $host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME']; } return $host; } /** * Marks a function as deprecated and informs when it has been used. * * There is a hook give_deprecated_function_run that will be called that can be used * to get the backtrace up to what file and function called the deprecated * function. * * The current behavior is to trigger a user error if WP_DEBUG is true. * * This function is to be used in every function that is deprecated. * * @param string $function The function that was called. * @param string $version The plugin version that deprecated the function. * @param string $replacement Optional. The function that should have been called. * @param array $backtrace Optional. Contains stack backtrace of deprecated function. * * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead, * and the version the function was deprecated in. * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do * trigger or false to not trigger error. */ function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) { /** * Fires while give deprecated function call occurs. * * Allow you to hook to deprecated function call. * * @param string $function The function that was called. * @param string $replacement Optional. The function that should have been called. * @param string $version The plugin version that deprecated the function. * * @since 1.0 */ do_action( 'give_deprecated_function_run', $function, $replacement, $version ); $show_errors = current_user_can( 'manage_options' ); // Allow plugin to filter the output error trigger. if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) { if ( ! is_null( $replacement ) ) { trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since GiveWP version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) ); 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. // Alternatively we could dump this to a file. } else { trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since GiveWP version %2$s with no alternative available.', 'give' ), $function, $version ) ); 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. // Alternatively we could dump this to a file. } } } /** * Give Get Admin ID * * Helper function to return the ID of the post for admin usage * * @return string $post_id */ function give_get_admin_post_id() { $post_id = isset( $_REQUEST['post'] ) ? absint( $_REQUEST['post'] ) : null; $post_id = ! empty( $post_id ) ? $post_id : ( isset( $_REQUEST['post_id'] ) ? absint( $_REQUEST['post_id'] ) : null ); $post_id = ! empty( $post_id ) ? $post_id : ( isset( $_REQUEST['post_ID'] ) ? absint( $_REQUEST['post_ID'] ) : null ); return $post_id; } /** * Get PHP Arg Separator Output * * @return string Arg separator output * @since 1.0 */ function give_get_php_arg_separator_output() { return ini_get( 'arg_separator.output' ); } /** * Month Num To Name * * Takes a month number and returns the name three letter name of it. * * @param int $n * * @return string Short month name * @since 1.0 */ function give_month_num_to_name( $n ) { $timestamp = mktime( 0, 0, 0, $n, 1, 2005 ); return date_i18n( 'M', $timestamp ); } /** * Checks whether function is disabled. * * @param string $function Name of the function. * * @return bool Whether or not function is disabled. * @since 1.0 */ function give_is_func_disabled( $function ) { $disabled = explode( ',', ini_get( 'disable_functions' ) ); return in_array( $function, $disabled ); } /** * Create SVG library function * * @param string $icon * * @return string */ function give_svg_icons( $icon ) { // Store your SVGs in an associative array $svgs = [ 'microphone' => '', 'alert' => '', 'placemark' => '', 'give_grey' => '', 'give_cpt_icon' => '', ]; // Return the chosen icon's SVG string return $svgs[ $icon ]; } /** * Modify Admin Nav Menu Label * * @param object $post_type The current object to add a menu items meta box for. * * @return mixed * @since 1.3 */ function modify_nav_menu_meta_box_object( $post_type ) { if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) { $post_type->labels->name = esc_html__( 'Donation Forms', 'give' ); } return $post_type; } add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' ); /** * Show Donation Forms Post Type in Appearance > Menus by default on fresh install. * * @return bool * @todo Remove this, when WordPress Core ticket is resolved (https://core.trac.wordpress.org/ticket/16828). * * @since 1.8.14 */ function give_donation_metabox_menu() { // Get Current Screen. $screen = get_current_screen(); // Proceed, if current screen is navigation menus. if ( 'nav-menus' === $screen->id && give_is_setting_enabled( give_get_option( 'forms_singular' ) ) && ! get_user_option( 'give_is_donation_forms_menu_updated' ) ) { // Return false, if it fails to retrieve hidden meta box list and is not admin. if ( ! is_admin() || ( ! $hidden_meta_boxes = get_user_option( 'metaboxhidden_nav-menus' ) ) ) { return false; } // Return false, In case, we don't find 'Donation Form' in hidden meta box list. if ( ! in_array( 'add-post-type-give_forms', $hidden_meta_boxes, true ) ) { return false; } // Exclude 'Donation Form' value from hidden meta box's list. $hidden_meta_boxes = array_diff( $hidden_meta_boxes, [ 'add-post-type-give_forms' ] ); // Get current user ID. $user = wp_get_current_user(); update_user_option( $user->ID, 'metaboxhidden_nav-menus', $hidden_meta_boxes, true ); update_user_option( $user->ID, 'give_is_donation_forms_menu_updated', true, true ); } } add_action( 'current_screen', 'give_donation_metabox_menu' ); /** * Array_column backup usage * * This file is part of the array_column library. * * @since : 1.3.0.1 * * @copyright Copyright (c) Ben Ramsey (http://benramsey.com) * @license https://opensource.org/licenses/MIT MIT */ if ( ! function_exists( 'array_column' ) ) { /** * Returns the values from a single column of the input array, identified by * the $columnKey. * * Optionally, you may provide an $indexKey to index the values in the returned * array by the values from the $indexKey column in the input array. * * @param array $input A multi-dimensional array (record set) from which to pull * a column of values. * @param int|string $columnKey The column of values to return. This value may be the * integer key of the column you wish to retrieve, or it * may be the string key name for an associative array. * @param mixed $indexKey (Optional.) The column to use as the index/keys for * the returned array. This value may be the integer key * of the column, or it may be the string key name. * * @return array|boolean|null */ function array_column( $input = null, $columnKey = null, $indexKey = null ) { // Using func_get_args() in order to check for proper number of // parameters and trigger errors exactly as the built-in array_column() // does in PHP 5.5. $argc = func_num_args(); $params = func_get_args(); if ( $argc < 2 ) { trigger_error( sprintf( 'array_column() expects at least 2 parameters, %s given.', $argc ), E_USER_WARNING ); return null; } if ( ! is_array( $params[0] ) ) { trigger_error( sprintf( 'array_column() expects parameter 1 to be array, %s given.', gettype( $params[0] ) ), E_USER_WARNING ); return null; } if ( ! is_int( $params[1] ) && ! is_float( $params[1] ) && ! is_string( $params[1] ) && $params[1] !== null && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) ) ) { trigger_error( 'array_column(): The column key should be either a string or an integer.', E_USER_WARNING ); return false; } if ( isset( $params[2] ) && ! is_int( $params[2] ) && ! is_float( $params[2] ) && ! is_string( $params[2] ) && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) ) ) { trigger_error( 'array_column(): The index key should be either a string or an integer.', E_USER_WARNING ); return false; } $paramsInput = $params[0]; $paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null; $paramsIndexKey = null; if ( isset( $params[2] ) ) { if ( is_float( $params[2] ) || is_int( $params[2] ) ) { $paramsIndexKey = (int) $params[2]; } else { $paramsIndexKey = (string) $params[2]; } } $resultArray = []; foreach ( $paramsInput as $row ) { $key = $value = null; $keySet = $valueSet = false; if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) { $keySet = true; $key = (string) $row[ $paramsIndexKey ]; } if ( $paramsColumnKey === null ) { $valueSet = true; $value = $row; } elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) { $valueSet = true; $value = $row[ $paramsColumnKey ]; } if ( $valueSet ) { if ( $keySet ) { $resultArray[ $key ] = $value; } else { $resultArray[] = $value; } } } return $resultArray; } }// End if(). /** * Determines the receipt visibility status. * * @param int $donation_id Donation ID. * * @return bool Whether the receipt is visible or not. * @since 1.3.2 */ function give_can_view_receipt( $donation_id ) { global $give_receipt_args; $donor = false; $can_view_receipt = false; // Bail out, if donation id doesn't exist. if ( empty( $donation_id ) ) { return $can_view_receipt; } $give_receipt_args['id'] = $donation_id; // Add backward compatibility. if ( ! is_numeric( $donation_id ) ) { $give_receipt_args['id'] = give_get_donation_id_by_key( $donation_id ); } // Return to download receipts from admin panel. if ( current_user_can( 'export_give_reports' ) ) { /** * This filter will be used to modify can view receipt response when accessed from admin. * * @since 2.3.1 */ return apply_filters( 'give_can_admin_view_receipt', true ); } if ( is_user_logged_in() || current_user_can( 'view_give_sensitive_data' ) ) { // Proceed only, if user is logged in or can view sensitive Give data. $donor = Give()->donors->get_donor_by( 'user_id', get_current_user_id() ); } elseif ( ! is_user_logged_in() ) { // Check whether it is purchase session? // This condition is to show receipt to donor after donation. $purchase_session = give_get_purchase_session(); if ( ! empty( $purchase_session ) && absint( $purchase_session['donation_id'] ) === absint( $donation_id ) ) { $donor = Give()->donors->get_donor_by( 'email', $purchase_session['user_email'] ); } // Check whether it is receipt access session? $receipt_session = give_get_receipt_session(); $email_access_token = ! empty( $_COOKIE['give_nl'] ) ? give_clean( $_COOKIE['give_nl'] ) : false; if ( ! empty( $receipt_session ) || ( give_is_setting_enabled( give_get_option( 'email_access' ) ) && ! empty( $email_access_token ) ) ) { $donor = ! empty( $email_access_token ) ? Give()->donors->get_donor_by_token( $email_access_token ) : false; } } // If donor object exists, compare the donation ids of donor with the donation receipt donor tries to access. if ( is_object( $donor ) ) { $is_donor_donated = in_array( (int) $donation_id, array_map( 'absint', explode( ',', $donor->payment_ids ) ), true ); $can_view_receipt = $is_donor_donated ? true : $can_view_receipt; if ( ! $is_donor_donated ) { Give()->session->set( 'donor_donation_mismatch', true ); } } return (bool) apply_filters( 'give_can_view_receipt', $can_view_receipt, $donation_id ); } /** * Fallback for cal_days_in_month * * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar */ if ( ! function_exists( 'cal_days_in_month' ) ) { /** * cal_days_in_month * * @param int $calendar * @param int $month * @param int $year * * @return bool|string */ function cal_days_in_month( $calendar, $month, $year ) { return date( 't', mktime( 0, 0, 0, $month, 1, $year ) ); } } /** * Get plugin info including status, type, and license validation. * * @return array Plugin info plus status, type, and license validation if * available. * @since 1.8.0 * * @todo update this function to query give addon and additional * * This is an enhanced version of get_plugins() that returns the status * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other` * and license validation for Give add-ons (`true` or `false`). Does not include * MU plugins. */ function give_get_plugins( $args = [] ) { $plugins = get_plugins(); $active_plugin_paths = (array) get_option( 'active_plugins', [] ); if ( is_multisite() ) { $network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', [] ) ); $active_plugin_paths = array_merge( $active_plugin_paths, $network_activated_plugin_paths ); } foreach ( $plugins as $plugin_path => $plugin_data ) { // Is plugin active? if ( in_array( $plugin_path, $active_plugin_paths ) ) { $plugins[ $plugin_path ]['Status'] = 'active'; } else { $plugins[ $plugin_path ]['Status'] = 'inactive'; } $dirname = strtolower( dirname( $plugin_path ) ); $plugins[ $plugin_path ]['Dir'] = $dirname; $plugins[ $plugin_path ]['Path'] = $plugin_path; // A third party add-on may contain more then one author like sofort, so it is better to compare array. $author = false !== strpos( $plugin_data['Author'], ',' ) ? array_map( 'trim', explode( ',', $plugin_data['Author'] ) ) : [ $plugin_data['Author'] ]; // Is the plugin a Give add-on? if ( false !== strpos( $dirname, 'give-' ) && ( false !== strpos( $plugin_data['PluginURI'], 'givewp.com' ) || array_intersect( $author, [ 'WordImpress', 'GiveWP' ] ) ) ) { // Plugin is a Give-addon. $plugins[ $plugin_path ]['Type'] = 'add-on'; $license_active = Give_License::get_license_by_plugin_dirname( $dirname ); // Does a valid license exist? $plugins[ $plugin_path ]['License'] = $license_active && 'valid' === $license_active['license']; } else { // Plugin is not a Give add-on. $plugins[ $plugin_path ]['Type'] = 'other'; } } if ( ! empty( $args['only_add_on'] ) ) { $plugins = array_filter( $plugins, static function( $plugin ) { return 'add-on' === $plugin['Type']; } ); } if ( ! empty( $args['only_premium_add_ons'] ) ) { $premiumAddonsListManger = give( PremiumAddonsListManager::class ); foreach ( $plugins as $key => $plugin ) { if ( 'add-on' !== $plugin['Type'] ) { unset( $plugins[ $key ] ); } if ( ! $premiumAddonsListManger->isPremiumAddons( $plugin['PluginURI'] ) ) { unset( $plugins[ $key ] ); } } } return $plugins; } /** * Check if terms enabled or not for form. * * @param $form_id * * @return bool * @since 1.8 */ function give_is_terms_enabled( $form_id ) { $form_option = give_get_meta( $form_id, '_give_terms_option', true ); if ( give_is_setting_enabled( $form_option, 'global' ) && give_is_setting_enabled( give_get_option( 'terms' ) ) ) { return true; } elseif ( give_is_setting_enabled( $form_option ) ) { return true; } else { return false; } } /** * Delete donation stats cache. * * @param string|array $date_range Date for stats. * Date value should be in today, yesterday, this_week, last_week, this_month, * last_month, this_quarter, last_quarter, this_year, last_year. For date value other, * all cache will be removed. * * @param array $args * * @return WP_Error|bool * @since 1.8.7 * * @todo Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key. */ function give_delete_donation_stats( $date_range = '', $args = [] ) { // Delete all cache. $status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) ); /** * Fire the action when donation stats delete. * * @param string|array $date_range * @param array $args * * @since 1.8.7 */ do_action( 'give_delete_donation_stats', $status, $date_range, $args ); return $status; } /** * Check if admin creating new donation form or not. * * @return bool * @since 2.0 */ function give_is_add_new_form_page() { $status = false; if ( false !== strpos( $_SERVER['REQUEST_URI'], '/wp-admin/post-new.php?post_type=give_forms' ) ) { $status = true; } return $status; } /** * Get Form/Payment meta. * * Note: This function will help you to get meta for payment and form. * If you want to get meta for donors then use get_meta of Give_Donor and * If you want to get meta for logs then use get_meta of Give_Logging->logmeta_db. * * @param int $id * @param string $meta_key * @param bool $single * @param bool $default * @param string $meta_type * * @return mixed * @since 1.8.8 */ function give_get_meta( $id, $meta_key = '', $single = false, $default = false, $meta_type = '' ) { switch ( $meta_type ) { case 'donation': $meta_value = Give()->payment_meta->get_meta( $id, $meta_key, $single ); break; case 'form': $meta_value = Give()->form_meta->get_meta( $id, $meta_key, $single ); break; case 'donor': $meta_value = Give()->donor_meta->get_meta( $id, $meta_key, $single ); break; default: $meta_value = get_post_meta( $id, $meta_key, $single ); } /** * Filter the meta value * * @since 1.8.8 */ $meta_value = apply_filters( 'give_get_meta', $meta_value, $id, $meta_key, $default, $meta_type ); if ( ( empty( $meta_key ) || empty( $meta_value ) ) && $default ) { $meta_value = $default; } return $meta_value; } /** * Update Form/Payment meta. * * @param int $id * @param string $meta_key * @param mixed $meta_value * @param mixed $prev_value * @param string $meta_type * * @return mixed * @since 1.8.8 */ function give_update_meta( $id, $meta_key, $meta_value, $prev_value = '', $meta_type = '' ) { switch ( $meta_type ) { case 'donation': $status = Give()->payment_meta->update_meta( $id, $meta_key, $meta_value, $prev_value ); break; case 'form': $status = Give()->form_meta->update_meta( $id, $meta_key, $meta_value, $prev_value ); break; case 'donor': $status = Give()->donor_meta->update_meta( $id, $meta_key, $meta_value, $prev_value ); break; default: $status = update_post_meta( $id, $meta_key, $meta_value, $prev_value ); } /** * Filter the meta value update status * * @since 1.8.8 */ return apply_filters( 'give_update_meta', $status, $id, $meta_key, $meta_value, $meta_type ); } /** * Delete Form/Payment meta. * * @param int $id * @param string $meta_key * @param string $meta_value * @param string $meta_type * * @return mixed * @since 1.8.8 */ function give_delete_meta( $id, $meta_key, $meta_value = '', $meta_type = '' ) { switch ( $meta_type ) { case 'donation': $status = Give()->payment_meta->delete_meta( $id, $meta_key, $meta_value ); break; case 'form': $status = Give()->form_meta->delete_meta( $id, $meta_key, $meta_value ); break; case 'donor': $status = Give()->donor_meta->delete_meta( $id, $meta_key, $meta_value ); break; default: $status = delete_post_meta( $id, $meta_key, $meta_value ); } /** * Filter the meta value delete status * * @since 1.8.8 */ return apply_filters( 'give_delete_meta', $status, $id, $meta_key, $meta_value, $meta_type ); } /** * Check if the upgrade routine has been run for a specific action * * @param string $upgrade_action The upgrade action to check completion for * * @return bool If the action has been added to the completed actions array * @since 1.0 */ function give_has_upgrade_completed( $upgrade_action = '' ) { // Bailout. if ( empty( $upgrade_action ) ) { return false; } // Fresh install? // If fresh install then all upgrades will be consider as completed. $is_fresh_install = ! Give_Cache_Setting::get_option( 'give_version' ); if ( $is_fresh_install ) { return true; } $completed_upgrades = give_get_completed_upgrades(); return in_array( $upgrade_action, $completed_upgrades ); } /** * For use when doing 'stepped' upgrade routines, to see if we need to start somewhere in the middle * * @return mixed When nothing to resume returns false, otherwise starts the upgrade where it left off * @since 1.8 */ function give_maybe_resume_upgrade() { $doing_upgrade = get_option( 'give_doing_upgrade', false ); if ( empty( $doing_upgrade ) ) { return false; } return $doing_upgrade; } /** * Adds an upgrade action to the completed upgrades array * * @param string $upgrade_action The action to add to the completed upgrades array * * @return bool If the function was successfully added * @since 1.0 */ function give_set_upgrade_complete( $upgrade_action = '' ) { if ( empty( $upgrade_action ) ) { return false; } $completed_upgrades = give_get_completed_upgrades(); $completed_upgrades[] = $upgrade_action; // Remove any blanks, and only show uniques. $completed_upgrades = array_unique( array_values( $completed_upgrades ) ); /** * Fire the action when any upgrade set to complete. * * @since 1.8.12 */ do_action( 'give_set_upgrade_completed', $upgrade_action, $completed_upgrades ); return update_option( 'give_completed_upgrades', $completed_upgrades, false ); } /** * Get's the array of completed upgrade actions * * @return array The array of completed upgrades * @since 1.0 */ function give_get_completed_upgrades() { return (array) Give_Cache_Setting::get_option( 'give_completed_upgrades' ); } /** * In 2.0 we updated table for log, payment and form. * * Note: internal purpose only. * * @param string $type Context for table * * @return null|array * @since 2.0 * @global wpdb $wpdb */ function __give_v20_bc_table_details( $type ) { global $wpdb; $table = []; // Bailout. if ( empty( $type ) ) { return null; } switch ( $type ) { case 'form': $table['name'] = $wpdb->formmeta; $table['column']['id'] = 'form_id'; break; case 'payment': $table['name'] = $wpdb->donationmeta; $table['column']['id'] = Give()->payment_meta->get_meta_type() . '_id'; } // Backward compatibility. if ( ! give_has_upgrade_completed( 'v20_move_metadata_into_new_table' ) ) { $table['name'] = $wpdb->postmeta; $table['column']['id'] = 'post_id'; } return $table; } /** * Remove the Give transaction pages from WP search results. * * @param WP_Query $query * * @since 1.8.13 */ function give_remove_pages_from_search( $query ) { if ( ! $query->is_admin && $query->is_search && $query->is_main_query() ) { $transaction_failed = give_get_option( 'failure_page', 0 ); $success_page = give_get_option( 'success_page', 0 ); $args = apply_filters( 'give_remove_pages_from_search', [ $transaction_failed, $success_page, ], $query ); $query->set( 'post__not_in', $args ); } } add_action( 'pre_get_posts', 'give_remove_pages_from_search', 10, 1 ); /** * Inserts a new key/value before a key in the array. * * @param string $key The key to insert before. * @param array $array An array to insert in to. * @param string $new_key The key to insert. * @param array|string $new_value An value to insert. * * @return array The new array if the key exists, the passed array otherwise. * * @since 1.8.13 * * @see array_insert_before() */ function give_array_insert_before( $key, array &$array, $new_key, $new_value ) { if ( array_key_exists( $key, $array ) ) { $new = []; foreach ( $array as $k => $value ) { if ( $k === $key ) { $new[ $new_key ] = $new_value; } $new[ $k ] = $value; } return $new; } return $array; } /** * Inserts a new key/value after a key in the array. * * @param string $key The key to insert after. * @param array $array An array to insert in to. * @param string $new_key The key to insert. * @param array|string $new_value An value to insert. * * @return array The new array if the key exists, the passed array otherwise. * * @since 1.8.13 * * @see array_insert_before() */ function give_array_insert_after( $key, array &$array, $new_key, $new_value ) { if ( array_key_exists( $key, $array ) ) { $new = []; foreach ( $array as $k => $value ) { $new[ $k ] = $value; if ( $k === $key ) { $new[ $new_key ] = $new_value; } } return $new; } return $array; } /** * Pluck a certain field out of each object in a list. * * This has the same functionality and prototype of * array_column() (PHP 5.5) but also supports objects. * * @param array $list List of objects or arrays * @param int|string $field Field from the object to place instead of the entire object * @param int|string $index_key Optional. Field from the object to use as keys for the new array. * Default null. * * @return array Array of found values. If `$index_key` is set, an array of found values with keys * corresponding to `$index_key`. If `$index_key` is null, array keys from the original * `$list` will be preserved in the results. * @since 1.8.13 */ function give_list_pluck( $list, $field, $index_key = null ) { if ( ! $index_key ) { /** * This is simple. Could at some point wrap array_column() * if we knew we had an array of arrays. */ foreach ( $list as $key => $value ) { if ( is_object( $value ) ) { if ( isset( $value->$field ) ) { $list[ $key ] = $value->$field; } } else { if ( isset( $value[ $field ] ) ) { $list[ $key ] = $value[ $field ]; } } } return $list; } /* * When index_key is not set for a particular item, push the value * to the end of the stack. This is how array_column() behaves. */ $newlist = []; foreach ( $list as $value ) { if ( is_object( $value ) ) { if ( isset( $value->$index_key ) ) { $newlist[ $value->$index_key ] = $value->$field; } else { $newlist[] = $value->$field; } } else { if ( isset( $value[ $index_key ] ) ) { $newlist[ $value[ $index_key ] ] = $value[ $field ]; } else { $newlist[] = $value[ $field ]; } } } $list = $newlist; return $list; } /** * Add meta data field to a donor. * * @param int $donor_id Donor ID. * @param string $meta_key Metadata name. * @param mixed $meta_value Metadata value. Must be serializable if non-scalar. * @param bool $unique Optional. Whether the same key should not be added. * Default false. * * @return int|false Meta ID on success, false on failure. * @since 1.8.13 */ function add_donor_meta( $donor_id, $meta_key, $meta_value, $unique = false ) { return add_metadata( 'give_customer', $donor_id, $meta_key, $meta_value, $unique ); } /** * Remove metadata matching criteria from a Donor meta. * * You can match based on the key, or key and value. Removing based on key and * value, will keep from removing duplicate metadata with the same key. It also * allows removing all metadata matching key, if needed. * * @param int $donor_id Donor ID * @param string $meta_key Metadata name. * @param mixed $meta_value Optional. Metadata value. * * @return bool True on success, false on failure. * @since 1.8.13 */ function delete_donor_meta( $donor_id, $meta_key, $meta_value = '' ) { return delete_metadata( 'give_customer', $donor_id, $meta_key, $meta_value ); } /** * Retrieve donor meta field for a donor meta table. * * @param int $donor_id Donor ID. * @param string $key Optional. The meta key to retrieve. By default, returns data for all keys. * @param bool $single Whether to return a single value. * * @return mixed Will be an array if $single is false. Will be value of meta data field if $single * is true. * @since 1.8.13 */ function get_donor_meta( $donor_id, $key = '', $single = false ) { return get_metadata( 'give_customer', $donor_id, $key, $single ); } /** * Update customer meta field based on Donor ID. * * If the meta field for the donor does not exist, it will be added. * * @param int $donor_id Donor ID. * @param string $meta_key Metadata key. * @param mixed $meta_value Metadata value. * @param mixed $prev_value Optional. Previous value to check before removing. * * @return int|bool Meta ID if the key didn't exist, true on successful update, false on failure. * @since 1.8.13 */ function update_donor_meta( $donor_id, $meta_key, $meta_value, $prev_value = '' ) { return update_metadata( 'give_customer', $donor_id, $meta_key, $meta_value, $prev_value ); } /** * Give recalculate income and donation of the donation from ID * * @param int $form_id Form id of which recalculation needs to be done. * * @return void * @since 1.8.13 */ function give_recount_form_income_donation( $form_id = 0 ) { // Check if form id is not empty. if ( ! empty( $form_id ) ) { /** * Filter to modify payment status. * * @since 1.8.13 */ $accepted_statuses = apply_filters( 'give_recount_accepted_statuses', [ 'publish' ] ); /** * Filter to modify args of payment query before recalculating the form total * * @since 1.8.13 */ $args = apply_filters( 'give_recount_form_stats_args', [ 'give_forms' => $form_id, 'status' => $accepted_statuses, 'number' => - 1, 'fields' => 'ids', ] ); $totals = [ 'sales' => 0, 'earnings' => 0, ]; $payments = new Give_Payments_Query( $args ); $payments = $payments->get_payments(); if ( $payments ) { foreach ( $payments as $payment ) { // Ensure acceptable status only. if ( ! in_array( $payment->post_status, $accepted_statuses ) ) { continue; } // Ensure only payments for this form are counted. if ( $payment->form_id != $form_id ) { continue; } $totals['sales'] ++; $totals['earnings'] += $payment->total; } } give_update_meta( $form_id, '_give_form_sales', $totals['sales'] ); give_update_meta( $form_id, '_give_form_earnings', give_sanitize_amount_for_db( $totals['earnings'] ) ); }// End if(). } /** * Get attribute string * * @param array $attributes * @param array $default_attributes * * @return string * @since 1.8.17 */ function give_get_attribute_str( $attributes, $default_attributes = [] ) { $attribute_str = ''; if ( isset( $attributes['attributes'] ) ) { $attributes = $attributes['attributes']; } if ( ! empty( $default_attributes ) ) { $attributes = wp_parse_args( $attributes, $default_attributes ); } if ( empty( $attributes ) ) { return $attribute_str; } foreach ( $attributes as $tag => $value ) { if ( 'value' == $tag ) { $value = esc_attr( $value ); } $attribute_str .= " {$tag}=\"{$value}\""; } return trim( $attribute_str ); } /** * Get the upload dir path * * @return string $wp_upload_dir; * @since 1.8.17 */ function give_get_wp_upload_dir() { $wp_upload_dir = wp_upload_dir(); return ( ! empty( $wp_upload_dir['path'] ) ? $wp_upload_dir['path'] : false ); } /** * Get the data from uploaded JSON file * * @param string $file_name filename of the json file that is being uploaded * * @return string|bool $file_contents File content * @since 1.8.17 */ function give_get_core_settings_json( $file_name ) { $upload_dir = give_get_wp_upload_dir(); $file_path = $upload_dir . '/' . $file_name; if ( is_wp_error( $file_path ) || empty( $file_path ) ) { Give_Admin_Settings::add_error( 'give-import-csv', __( 'Please upload or provide a valid JSON file.', 'give' ) ); } $file_contents = file_get_contents( $file_path ); return $file_contents; } /** * Get number of donation to show when user is not login. * * @return int $country The two letter country code for the site's base country * @since 1.8.17 */ function give_get_limit_display_donations() { return give_get_option( 'limit_display_donations', 1 ); } /** * Add footer to the table when donor is view the donation history page with out login * * @since 1.8.17 */ function give_donation_history_table_end() { $email = Give()->session->get( 'give_email' ); ?> <tfoot> <tr> <td colspan="9999"> <div class="give-security-wrap"> <div class="give-security-column give-security-description-wrap"> <?php echo sprintf( __( 'For security reasons, please confirm your email address (%s) to view your complete donation history.', 'give' ), $email ); ?> </div> <div class="give-security-column give-security-button-wrap"> <a href="#" data-email="<?php echo $email; ?>" id="give-confirm-email-btn" class="give-confirm-email-btn give-btn"> <?php _e( 'Confirm Email', 'give' ); ?> </a> <span><?php _e( 'Email Sent!', 'give' ); ?></span> </div> </div> </td> </tr> </tfoot> <?php } /** * Wrapper for _doing_it_wrong. * * @param string $function * @param string $message * @param string $version deprecated * * @return void * @since 1.8.18 * @since 2.5.13 Refactor function */ function give_doing_it_wrong( $function, $message, $version = null ) { /** * Fires while calling function incorrectly. * * Allow you to hook to incorrect function call. * * @param string $function The function that was called. * @param string $replacement Optional. The function that should have been called. * @param string $version The plugin version that deprecated the function. * * @since 2.5.13 */ do_action( 'give_doing_it_wrong', $function, $message, $version ); $show_errors = current_user_can( 'manage_options' ); // Allow plugin to filter the output error trigger. if ( WP_DEBUG && apply_filters( 'give_doing_it_wrong_trigger_error', $show_errors ) ) { trigger_error( sprintf( __( '%1$s was called <strong>incorrectly</strong>. %2$s', 'give' ), $function, $message ) ); trigger_error( print_r( wp_debug_backtrace_summary(), 1 ) );// Limited to previous 1028 characters, but since we only need to move back 1 in stack that should be fine. } } /** * Remove limit from running php script complete. * * @since 1.8.18 */ function give_ignore_user_abort() { ignore_user_abort( true ); if ( ! give_is_func_disabled( 'set_time_limit' ) && ! ini_get( 'safe_mode' ) ) { set_time_limit( 0 ); } } /** * Get post type count. * * @param string $post_type * @param array $args * * @return int * @since 2.0.2 */ function give_get_total_post_type_count( $post_type = '', $args = [] ) { global $wpdb; $where = ''; if ( ! $post_type ) { return 0; } // Bulit where query if ( ! empty( $post_type ) ) { $where .= ' WHERE'; if ( is_array( $post_type ) ) { $where .= " post_type='" . implode( "' OR post_type='", $post_type ) . "'"; } else { $where .= " post_type='{$post_type}'"; } } $result = $wpdb->get_var( "SELECT count(ID) FROM {$wpdb->posts}{$where}" ); return absint( $result ); } /** * Define a constant if it is not already defined. * * @param string $name Constant name. * @param string $value Value. * * @credit WooCommerce * @since 2.0.5 */ function give_maybe_define_constant( $name, $value ) { if ( ! defined( $name ) ) { define( $name, $value ); } } /** * Decode time short tag in string * * @param string $string * @param int $timestamp * * @return string * @since 2.1.0 */ function give_time_do_tags( $string, $timestamp = 0 ) { $current_time = ! empty( $timestamp ) ? $timestamp : current_time( 'timestamp' ); $formatted_string = str_replace( [ '{D}', '{DD}', '{M}', '{MM}', '{YY}', '{YYYY}', '{H}', '{HH}', '{N}', '{S}', ], [ date( 'j', $current_time ), date( 'd', $current_time ), date( 'n', $current_time ), date( 'm', $current_time ), date( 'Y', $current_time ), date( 'Y', $current_time ), date( 'G', $current_time ), date( 'H', $current_time ), date( 's', $current_time ), ], $string ); /** * Filter the parsed string. * * @since 2.1.0 */ return apply_filters( 'give_time_do_tags', $formatted_string, $string, $timestamp ); } /** * Check if Company field enabled or not for form or globally. * * @param $form_id * * @return bool * @since 2.1 */ function give_is_company_field_enabled( $form_id ) { $form_setting_val = give_get_meta( $form_id, '_give_company_field', true ); $global_setting_val = give_get_option( 'company_field' ); if ( ! empty( $form_setting_val ) ) { if ( give_is_setting_enabled( $form_setting_val, [ 'required', 'optional' ] ) ) { return true; } elseif ( 'global' === $form_setting_val && give_is_setting_enabled( $global_setting_val, [ 'required', 'optional', ] ) ) { return true; } else { return false; } } elseif ( give_is_setting_enabled( $global_setting_val, [ 'required', 'optional' ] ) ) { return true; } else { return false; } } /** * Check if Last Name field is required * * @param $form_id * * @return bool * @since 2.15.0 */ function give_is_last_name_required( $form_id ) { $form_setting_val = give_get_meta( $form_id, '_give_last_name_field_required', true ); $global_setting_val = give_get_option( 'last_name_field_required' ); if ( ! empty( $form_setting_val ) ) { if ( 'required' === $form_setting_val ) { return true; } return 'global' === $form_setting_val && 'required' === $global_setting_val; } return 'required' === $global_setting_val; } /** * Check if anonymous donation field enabled or not for form or globally. * * @param $form_id * * @return bool * @since 2.1 */ function give_is_anonymous_donation_field_enabled( $form_id ) { $form_setting_val = give_get_meta( $form_id, '_give_anonymous_donation', true, 'global' ); $global_setting_val = give_get_option( 'anonymous_donation', 'disabled' ); if ( ! empty( $form_setting_val ) ) { if ( give_is_setting_enabled( $form_setting_val ) ) { return true; } elseif ( 'global' === $form_setting_val && give_is_setting_enabled( $global_setting_val ) ) { return true; } else { return false; } } elseif ( give_is_setting_enabled( $global_setting_val ) ) { return true; } return false; } /** * Check if donor comment field enabled or not for form or globally. * * @param $form_id * * @return bool * @since 2.1 */ function give_is_donor_comment_field_enabled( $form_id ) { $form_setting_val = give_get_meta( $form_id, '_give_donor_comment', true, 'global' ); $global_setting_val = give_get_option( 'donor_comment', 'disabled' ); if ( ! empty( $form_setting_val ) ) { if ( give_is_setting_enabled( $form_setting_val ) ) { return true; } elseif ( 'global' === $form_setting_val && give_is_setting_enabled( $global_setting_val ) ) { return true; } else { return false; } } elseif ( give_is_setting_enabled( $global_setting_val ) ) { return true; } return false; } /** * Get add-on user meta value information * Note: only for internal use. * * @param string $banner_addon_name Give add-on name. * * @return array * @since 2.1.0 */ function __give_get_active_by_user_meta( $banner_addon_name ) { global $wpdb; // Get the option key. $option_name = Give_Addon_Activation_Banner::get_banner_user_meta_key( $banner_addon_name ); $data = []; if ( empty( $GLOBALS['give_addon_activated_by_user'] ) ) { $GLOBALS['give_addon_activated_by_user'] = []; // Get the meta of activation banner by user. $activation_banners = $wpdb->get_results( " SELECT option_name, option_value FROM {$wpdb->options} WHERE option_name LIKE '%_active_by_user%' AND option_name LIKE '%give_addon%' ", ARRAY_A ); if ( ! empty( $activation_banners ) ) { $GLOBALS['give_addon_activated_by_user'] = array_combine( wp_list_pluck( $activation_banners, 'option_name' ), wp_list_pluck( $activation_banners, 'option_value' ) ); } } if ( array_key_exists( $option_name, $GLOBALS['give_addon_activated_by_user'] ) ) { $data = maybe_unserialize( $GLOBALS['give_addon_activated_by_user'][ $option_name ] ); } return $data; } /** * Get time interval for which nonce is valid * * @return int * @since 2.1.3 */ function give_get_nonce_life() { /** * Filters the lifespan of nonces in seconds. * * @see wp-inlucdes/pluggable.php:wp_nonce_tick */ return (int) apply_filters( 'nonce_life', DAY_IN_SECONDS ); } /** * Get nonce field without id * * @param string $action * @param string $name * @param bool $referer * * @return string * @since 2.1.3 */ function give_get_nonce_field( $action, $name, $referer = false ) { return str_replace( "id=\"{$name}\"", '', wp_nonce_field( $action, $name, $referer, false ) ); } /** * Display/Return a formatted goal for a donation form * * @since 3.16.0 Add form_id to the array return * @since 2.1 * * @param int|Give_Donate_Form $form Form ID or Form Object. * * @return array */ function give_goal_progress_stats( $form ) { if ( ! $form instanceof Give_Donate_Form ) { $form = new Give_Donate_Form( $form ); } $goal_format = give_get_form_goal_format( $form->ID ); /** * Filter the form. * @since 1.8.8 */ $total_goal = apply_filters( 'give_goal_amount_target_output', round( give_maybe_sanitize_amount( $form->goal ), 2 ), $form->ID, $form ); switch ( $goal_format ) { case 'donation': /** * Filter the form donations. * * @since 2.1 */ $actual = apply_filters( 'give_goal_donations_raised_output', $form->sales, $form->ID, $form ); break; case 'donors': /** * Filter to modify total number if donor for the donation form. * * @param int $donors Total number of donors that donated to the form. * @param int $form_id Donation Form ID. * @param Give_Donate_Form $form instances of Give_Donate_Form. * * @return int $donors Total number of donors that donated to the form. * @since 2.1.3 */ $actual = apply_filters( 'give_goal_donors_target_output', give_get_form_donor_count( $form->ID ), $form->ID, $form ); break; default: /** * Filter the form income. * * @since 3.16.0 Revert changes implemented on the 3.14.0 version * @since 3.14.0 Replace "$form->earnings" with (new DonationQuery())->form($form->ID)->sumIntendedAmount() * @since 1.8.8 */ $actual = apply_filters( 'give_goal_amount_raised_output', $form->earnings, $form->ID, $form ); break; } $progress = $total_goal ? round( ( $actual / $total_goal ) * 100, 2 ) : 0; $stats_array = [ 'raw_actual' => $actual, 'raw_goal' => $total_goal, ]; /** * Filter the goal progress output * * @since 1.8.8 */ $progress = apply_filters( 'give_goal_amount_funded_percentage_output', $progress, $form->ID, $form ); // Define Actual Goal based on the goal format. switch ( $goal_format ) { case 'percentage': $actual = "{$progress}%"; $total_goal = ''; break; case 'amount' === $goal_format: $actual = give_currency_filter( give_format_amount( $actual ) ); $total_goal = give_currency_filter( give_format_amount( $total_goal ) ); break; default: $actual = give_format_amount( $actual, [ 'decimal' => false ] ); $total_goal = give_format_amount( $total_goal, [ 'decimal' => false ] ); break; } $stats_array = array_merge( [ 'progress' => $progress, 'actual' => $actual, 'goal' => $total_goal, 'format' => $goal_format, 'form_id' => $form->ID ], $stats_array ); /** * Filter the goal stats * * @since 2.1 */ return apply_filters( 'give_goal_progress_stats', $stats_array ); } /** * Get the admin messages key to show the notices. * * @return array $message admin message key. * @since 2.1.4 */ function give_get_admin_messages_key() { $messages = empty( $_GET['give-messages'] ) ? [] : give_clean( $_GET['give-messages'] ); // backward compatibility. if ( ! empty( $_GET['give-message'] ) ) { $messages[] = give_clean( $_GET['give-message'] ); } /** * Filter to modify the admin messages key. * * @param array $message admin message key. * * @return array $message admin message key. * @since 2.1.4 */ return (array) apply_filters( 'give_get_admin_messages_key', $messages ); } /** * Get User Agent String. * * @return array|string * @since 2.1.4 */ function give_get_user_agent() { // Get User Agent. $user_agent = ! empty( $_SERVER['HTTP_USER_AGENT'] ) ? give_clean( $_SERVER['HTTP_USER_AGENT'] ) : ''; // WPCS: input var ok. return $user_agent; } /** * Set a cookie - wrapper for setcookie using WP constants. * * @param string $name Name of the cookie being set. * @param string $value Value of the cookie. * @param integer $expire Expiry of the cookie. * @param bool $secure Whether the cookie should be served only over https. * * @since 2.2.0 */ function give_setcookie( $name, $value, $expire = 0, $secure = false ) { if ( ! headers_sent() ) { setcookie( $name, $value, $expire, COOKIEPATH ? COOKIEPATH : '/', COOKIE_DOMAIN, $secure, apply_filters( 'give_cookie_httponly', false, $name, $value, $expire, $secure ) ); } } /** * Get formatted billing address. * * @param array $address * * @return string Formatted address. * @since 2.2.0 */ function give_get_formatted_address( $address = [] ) { $formatted_address = ''; /** * Address format. * * @since 2.2.0 */ $address_format = apply_filters( 'give_address_format_template', "{street_address}\n{city}, {state} {postal_code}\n{country}" ); preg_match_all( '/{([A-z0-9\-\_\ ]+)}/s', $address_format, $matches ); if ( ! empty( $matches ) && ! empty( $address ) ) { $address_values = []; foreach ( $matches[1] as $address_tag ) { $address_values[ $address_tag ] = ''; if ( isset( $address[ $address_tag ] ) ) { $address_values[ $address_tag ] = $address[ $address_tag ]; } } $formatted_address = str_ireplace( $matches[0], $address_values, $address_format ); } /** * Give get formatted address. * * @param string $formatted_address Formatted address. * @param string $address_format Format of the address. * * @since 2.2.0 */ $formatted_address = apply_filters( 'give_get_formatted_address', $formatted_address, $address_format, $address ); return $formatted_address; } /** * Get safe url for assets * Note: this function will return url without http protocol * * @param string $url URL * * @return string * @since 2.2.0 */ function give_get_safe_asset_url( $url ) { // Bailout, if empty URL passed. if ( empty( $url ) ) { return $url; } $schema = parse_url( $url, PHP_URL_SCHEME ); $schema_length = strlen( $schema ) + 1; $url = substr( $url, $schema_length ); /** * Fire the filter * * @since 2.2.0 */ return apply_filters( 'give_get_safe_asset_url', $url ); } /** * Give get formatted date. * Note: This function does not work well with localize translated date strings * * @param string $date Date. * @param string $format Date Format. * @param string $current_format Current date Format. * @param bool $localize * * @return string * @since 2.3.0 */ function give_get_formatted_date( $date, $format = 'Y-m-d', $current_format = '', $localize = false ) { $current_format = empty( $current_format ) ? give_date_format() : $current_format; $date_obj = DateTime::createFromFormat( $current_format, $date ); $formatted_date = ''; if ( $date_obj instanceof DateTime ) { $formatted_date = $localize ? date_i18n( $format, $date_obj->getTimestamp() ) : $date_obj->format( $format ); } /** * Give get formatted date. * * @param string $formatted_date Formatted date. * @param array * * @since 2.3.0 */ return apply_filters( 'give_get_formatted_date', $formatted_date, [ $date, $format, $current_format ] ); } /** * This function will be used to fetch the donation receipt link. * * @param int $donation_id Donation ID. * * @return string * @since 2.3.1 */ function give_get_receipt_link( $donation_id ) { return sprintf( '<a href="%1$s">%2$s</a>', esc_url( give_get_receipt_url( $donation_id ) ), esc_html__( 'View the receipt in your browser »', 'give' ) ); } /** * Get receipt_url * * @param int $donation_id Donation ID. * * @return string * @since 2.0 */ function give_get_receipt_url( $donation_id ) { $receipt_url = esc_url_raw( add_query_arg( [ 'donation_id' => $donation_id, ], give_get_history_page_uri() ) ); return $receipt_url; } /** * Get "View in browser" Receipt Link for email. * * @param int $donation_id Donation ID. * * @return string * @since 2.4.1 */ function give_get_view_receipt_link( $donation_id ) { return sprintf( '<a href="%1$s">%2$s</a>', give_get_view_receipt_url( $donation_id ), esc_html__( 'View the receipt in your browser »', 'give' ) ); } /** * Get "View in browser" Receipt URL for email. * * @param int $donation_id Donation ID. * * @return string * @since 2.4.1 */ function give_get_view_receipt_url( $donation_id ) { $receipt_url = esc_url_raw( add_query_arg( [ 'action' => 'view_in_browser', '_give_hash' => give_get_payment_key( $donation_id ), ], give_get_history_page_uri() ) ); return $receipt_url; } /** * This function is used to display donation receipt content based on the parameters. * * @param $args * * @return bool|mixed * @since 2.4.1 */ function give_display_donation_receipt( $args ) { global $give_receipt_args; $give_receipt_args = $args; ob_start(); $get_data = give_clean( filter_input_array( INPUT_GET ) ); $donation_id = ! empty( $get_data['donation_id'] ) ? $get_data['donation_id'] : false; $receipt_type = ! empty( $get_data['receipt_type'] ) ? $get_data['receipt_type'] : false; $give_receipt_args['id'] = $donation_id; if ( 'view_in_browser' !== $receipt_type ) { $email_access = give_get_option( 'email_access' ); $is_email_access = give_is_setting_enabled( $email_access ) && ! Give()->email_access->token_exists; // No donation id found & Email Access is Turned on. if ( ! $donation_id ) { if ( $is_email_access ) { give_get_template_part( 'email-login-form' ); } else { echo Give_Notices::print_frontend_notice( $args['error'], false, 'error' ); } return ob_get_clean(); } // Donation id provided, but user is logged out. Offer them the ability to login and view the receipt. if ( ! ( $user_can_view = give_can_view_receipt( $donation_id ) ) ) { if ( true === Give()->session->get( 'donor_donation_mismatch' ) ) { /** * This filter will be used to modify the donor mismatch text for front end error notice. * * @since 2.3.1 */ $donor_mismatch_text = apply_filters( 'give_receipt_donor_mismatch_notice_text', __( 'You are trying to access invalid donation receipt. Please try again.', 'give' ) ); echo Give_Notices::print_frontend_notice( $donor_mismatch_text, false, 'error' ); } elseif ( $is_email_access ) { give_get_template_part( 'email-login-form' ); } else { global $give_login_redirect; $give_login_redirect = give_get_current_page_url(); Give_Notices::print_frontend_notice( apply_filters( 'give_must_be_logged_in_error_message', __( 'You must be logged in to view this donation receipt.', 'give' ) ) ); give_get_template_part( 'shortcode', 'login' ); } return ob_get_clean(); } /** * Check if the user has permission to view the receipt. * * If user is logged in, user ID is compared to user ID of ID stored in payment meta * or if user is logged out and donation was made as a guest, the donation session is checked for * or if user is logged in and the user can view sensitive shop data. */ if ( ! apply_filters( 'give_user_can_view_receipt', $user_can_view, $args ) ) { return Give_Notices::print_frontend_notice( $args['error'], false, 'error' ); } } else { $donation_id = give_get_donation_id_by_key( $get_data['donation_id'] ); $give_receipt_args['id'] = $donation_id; } give_get_template_part( 'shortcode', 'receipt' ); return ob_get_clean(); } /** * Get plugin add-on readme.txt path * Note: only for internal use * * @param $plugin_slug * @param bool $by_plugin_name * * @return mixed|void * @since 2.5.0 */ function give_get_addon_readme_url( $plugin_slug, $by_plugin_name = false ) { if ( $by_plugin_name ) { $plugin_slug = Give_License::get_short_name( $plugin_slug ); } $website_url = trailingslashit( Give_License::get_website_url() ); /** * Filter the addon readme.txt url * * @since 2.1.4 */ $url = apply_filters( 'give_addon_readme_file_url', "{$website_url}downloads/plugins/{$plugin_slug}/readme.txt", $plugin_slug, $by_plugin_name ); return $url; } /** * Refresh all givewp license. * * @since 2.27.0 delete update_plugins transient instead of invalidate it * @since 2.5.0 * * @param bool $wp_check_updates * * @access public * @return array|WP_Error */ function give_refresh_licenses( $wp_check_updates = true ) { $give_licenses = get_option( 'give_licenses', [] ); $give_addons = give_get_plugins( [ 'only_premium_add_ons' => true ] ); if ( ! $give_licenses && ! $give_addons ) { return []; } $license_keys = $give_licenses ? implode( ',', array_keys( $give_licenses ) ) : ''; $unlicensed_give_addon = $give_addons ? array_values( array_diff( array_map( function ( $plugin_name ) { return trim( str_replace( 'Give - ', '', $plugin_name ) ); }, wp_list_pluck( $give_addons, 'Name', true ) ), wp_list_pluck( $give_licenses, 'item_name', true ) ) ) : []; $tmp = Give_License::request_license_api( [ 'edd_action' => 'check_licenses', 'licenses' => $license_keys, 'unlicensed' => implode( ',', $unlicensed_give_addon ), ], true ); if ( ! $tmp || is_wp_error( $tmp ) ) { return []; } // Prevent fatal error on WP 4.9.10 // Because wp_list_pluck accept only array or array of array in that version. // @see https://github.com/impress-org/give/issues/4176 $tmp = json_decode( json_encode( $tmp ), true ); // Remove unlicensed add-on from response. $tmp_unlicensed = []; foreach ( $tmp as $key => $data ) { if ( empty( $data ) ) { unset( $tmp[ "{$key}" ] ); continue; } if ( empty( $data['check_license'] ) ) { $tmp_unlicensed[ $key ] = $data; unset( $tmp[ "{$key}" ] ); } } $check_licenses = wp_list_pluck( $tmp, 'check_license' ); /* @var stdClass $data */ foreach ( $check_licenses as $key => $data ) { if ( is_wp_error( $data ) ) { continue; } if ( ! $data['success'] ) { unset( $give_licenses[ $key ] ); continue; } $give_licenses[ $key ] = $data; } $tmp_update_plugins = array_merge( array_filter( wp_list_pluck( $tmp, 'get_version' ) ), array_filter( wp_list_pluck( $tmp, 'get_versions' ) ) ); if ( $tmp_unlicensed ) { $tmp_update_plugins = array_merge( $tmp_update_plugins, $tmp_unlicensed ); } update_option( 'give_licenses', $give_licenses, 'no' ); update_option( 'give_get_versions', $tmp_update_plugins, 'no' ); $refresh = Give_License::refresh_license_status(); $refresh['time'] = time(); update_option( 'give_licenses_refreshed_last_checked', $refresh, 'no' ); // Tell WordPress to look for updates. if ( $wp_check_updates ) { delete_site_transient('update_plugins'); } return [ 'give_licenses' => $give_licenses, 'give_get_versions' => $tmp_update_plugins, ]; } /** * Check add-ons updates * Note: only for internal use * * @param stdClass $_transient_data Plugin updates information * * @return stdClass * @since 2.5.0 */ function give_check_addon_updates( $_transient_data ) { if ( ! is_object( $_transient_data ) ) { $_transient_data = new stdClass(); } $update_plugins = get_option( 'give_get_versions', [] ); $check_licenses = get_option( 'give_licenses', [] ); if ( ! $update_plugins ) { $data = give_refresh_licenses( false ); if ( empty( $data['give_get_versions'] ) || is_wp_error( $data ) ) { return $_transient_data; } $update_plugins = $data['give_get_versions']; } foreach ( $update_plugins as $key => $data ) { $plugins = ! empty( $check_licenses[ $key ] ) ? ( ! empty( $check_licenses[ $key ]['is_all_access_pass'] ) ? $data : [ $data ] ) : [ $data ]; foreach ( $plugins as $plugin ) { // This value will be empty if any error occurred when verifying version of add-on. if ( empty( $plugin['new_version'] ) ) { continue; } $plugin = array_map( 'maybe_unserialize', $plugin ); $tmp_plugin = Give_License::get_plugin_by_slug( $plugin['slug'] ); if ( ! $tmp_plugin ) { continue; } $plugin['plugin'] = $tmp_plugin['Path']; if ( - 1 !== version_compare( $tmp_plugin['Version'], $plugin['new_version'] ) ) { $_transient_data->no_update[ $tmp_plugin['Path'] ] = (object) $plugin; } else { $_transient_data->response[ $tmp_plugin['Path'] ] = (object) $plugin; } $_transient_data->checked[ $tmp_plugin['Path'] ] = $tmp_plugin['Version']; } } $_transient_data->last_checked = time(); return $_transient_data; } /** * Get page by title * * @since 2.26.0 * * @param string $page_title * @param string $output * @param string $post_type * * @return null|WP_Post */ function give_get_page_by_title(string $page_title, string $output = OBJECT, string $post_type = 'page') { $args = [ 'title' => $page_title, 'post_type' => $post_type, 'post_status' => get_post_stati(), 'posts_per_page' => 1, 'update_post_term_cache' => false, 'update_post_meta_cache' => false, 'no_found_rows' => true, 'orderby' => 'post_date ID', 'order' => 'ASC', ]; $query = new WP_Query($args); $pages = $query->posts; if (empty($pages)) { return null; } return get_post($pages[0], $output); }