Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../public_h.../wp-conte.../plugins/password.../includes
File: class-ppw-functions.php
<?php
[0] Fix | Delete
/**
[1] Fix | Delete
* Check condition and include plugin.php file
[2] Fix | Delete
*/
[3] Fix | Delete
if ( ! function_exists( 'is_plugin_active' ) ) {
[4] Fix | Delete
include_once( ABSPATH . 'wp-admin/includes/plugin.php' );
[5] Fix | Delete
}
[6] Fix | Delete
[7] Fix | Delete
/**
[8] Fix | Delete
* Escape a WP_Error object for passing directly to wp_die().
[9] Fix | Delete
*
[10] Fix | Delete
* The wp_die() function accepts an WP_Error object as the first parameter, but it
[11] Fix | Delete
* does not escape it\'s contents before printing it out to the user. By passing
[12] Fix | Delete
* the object through this function before giving it to wp_die(), the potential for
[13] Fix | Delete
* XSS should be avoided.
[14] Fix | Delete
*
[15] Fix | Delete
* Example:
[16] Fix | Delete
*
[17] Fix | Delete
* wp_die( my_prefix_escape_wp_error( $error ) );
[18] Fix | Delete
*
[19] Fix | Delete
* @param WP_Error $error The error to escape.
[20] Fix | Delete
*
[21] Fix | Delete
* @return WP_Error The escaped error.
[22] Fix | Delete
*/
[23] Fix | Delete
function ppw_escape_wp_error( $error ) {
[24] Fix | Delete
[25] Fix | Delete
$code = $error->get_error_code();
[26] Fix | Delete
[27] Fix | Delete
$error_data = $error->error_data;
[28] Fix | Delete
[29] Fix | Delete
if ( isset( $error_data[ $code ]['title'] ) ) {
[30] Fix | Delete
$error_data[ $code ]['title'] = wp_kses(
[31] Fix | Delete
$error->error_data[ $code ]['title'],
[32] Fix | Delete
'escape_wp_error_title'
[33] Fix | Delete
);
[34] Fix | Delete
$error->error_data = $error_data;
[35] Fix | Delete
}
[36] Fix | Delete
[37] Fix | Delete
$all_errors = $error->errors;
[38] Fix | Delete
[39] Fix | Delete
foreach ( $all_errors as $code => $errors ) {
[40] Fix | Delete
foreach ( $errors as $key => $message ) {
[41] Fix | Delete
$all_errors[ $code ][ $key ] = wp_kses(
[42] Fix | Delete
$message,
[43] Fix | Delete
'escape_wp_error_message'
[44] Fix | Delete
);
[45] Fix | Delete
}
[46] Fix | Delete
}
[47] Fix | Delete
[48] Fix | Delete
$error->errors = $all_errors;
[49] Fix | Delete
return $error;
[50] Fix | Delete
}
[51] Fix | Delete
[52] Fix | Delete
/**
[53] Fix | Delete
* Check data before update setting
[54] Fix | Delete
*
[55] Fix | Delete
* @param array $request Request data.
[56] Fix | Delete
* @param array $setting_keys Keys need to check.
[57] Fix | Delete
* @param bool $is_check_cookie Is check cookie.
[58] Fix | Delete
*
[59] Fix | Delete
* @return bool
[60] Fix | Delete
*/
[61] Fix | Delete
function ppw_free_is_setting_data_invalid( $request, $setting_keys, $is_check_cookie = true ) {
[62] Fix | Delete
if ( ppw_free_is_setting_keys_and_nonce_invalid( $request, PPW_Constants::GENERAL_FORM_NONCE ) ) {
[63] Fix | Delete
return true;
[64] Fix | Delete
}
[65] Fix | Delete
[66] Fix | Delete
$settings = $request['settings'];
[67] Fix | Delete
foreach ( $setting_keys as $key ) {
[68] Fix | Delete
if ( ! array_key_exists( $key, $settings ) ) {
[69] Fix | Delete
return true;
[70] Fix | Delete
}
[71] Fix | Delete
}
[72] Fix | Delete
[73] Fix | Delete
if ( ! $is_check_cookie ) {
[74] Fix | Delete
return false;
[75] Fix | Delete
}
[76] Fix | Delete
[77] Fix | Delete
// Check regular expression.
[78] Fix | Delete
return ppw_core_validate_cookie_expiry( $settings[ PPW_Constants::COOKIE_EXPIRED ] );
[79] Fix | Delete
}
[80] Fix | Delete
[81] Fix | Delete
/**
[82] Fix | Delete
* Check data before update entire site settings
[83] Fix | Delete
*
[84] Fix | Delete
* @param $request
[85] Fix | Delete
*
[86] Fix | Delete
* @return bool
[87] Fix | Delete
*/
[88] Fix | Delete
function ppw_free_is_entire_site_settings_data_invalid( $request ) {
[89] Fix | Delete
return ppw_free_is_setting_keys_and_nonce_invalid( $request, PPW_Constants::ENTIRE_SITE_FORM_NONCE );
[90] Fix | Delete
}
[91] Fix | Delete
[92] Fix | Delete
/**
[93] Fix | Delete
* @param $request
[94] Fix | Delete
* @param $nonce_key
[95] Fix | Delete
*
[96] Fix | Delete
* @return bool
[97] Fix | Delete
*/
[98] Fix | Delete
function ppw_free_is_setting_keys_and_nonce_invalid( $request, $nonce_key ) {
[99] Fix | Delete
if ( ! array_key_exists( 'settings', $request ) ||
[100] Fix | Delete
! array_key_exists( 'security_check', $request ) ) {
[101] Fix | Delete
return true;
[102] Fix | Delete
}
[103] Fix | Delete
[104] Fix | Delete
if ( ! wp_verify_nonce( $request['security_check'], $nonce_key ) ) {
[105] Fix | Delete
return true;
[106] Fix | Delete
}
[107] Fix | Delete
[108] Fix | Delete
return false;
[109] Fix | Delete
}
[110] Fix | Delete
[111] Fix | Delete
/**
[112] Fix | Delete
* Check error before create new password
[113] Fix | Delete
*
[114] Fix | Delete
* @param $request
[115] Fix | Delete
* @param $setting_keys
[116] Fix | Delete
*
[117] Fix | Delete
* @return bool
[118] Fix | Delete
*/
[119] Fix | Delete
function ppw_free_error_before_create_password( $request, $setting_keys ) {
[120] Fix | Delete
if ( ppw_free_is_setting_keys_and_nonce_invalid( $request, PPW_Constants::META_BOX_NONCE ) ) {
[121] Fix | Delete
return true;
[122] Fix | Delete
}
[123] Fix | Delete
[124] Fix | Delete
$settings = $request["settings"];
[125] Fix | Delete
foreach ( $setting_keys as $key ) {
[126] Fix | Delete
if ( ! array_key_exists( $key, $settings ) ) {
[127] Fix | Delete
return true;
[128] Fix | Delete
}
[129] Fix | Delete
}
[130] Fix | Delete
[131] Fix | Delete
return false;
[132] Fix | Delete
}
[133] Fix | Delete
[134] Fix | Delete
/**
[135] Fix | Delete
* Validate password type is global
[136] Fix | Delete
*
[137] Fix | Delete
* @param $new_global_passwords
[138] Fix | Delete
* @param $current_global_passwords
[139] Fix | Delete
* @param $current_roles_password
[140] Fix | Delete
*/
[141] Fix | Delete
function ppw_free_validate_password_type_global( $new_global_passwords, $current_global_passwords, $current_roles_password ) {
[142] Fix | Delete
if ( count( $new_global_passwords ) < 1 && empty( $current_global_passwords ) ) {
[143] Fix | Delete
wp_send_json(
[144] Fix | Delete
array(
[145] Fix | Delete
'is_error' => true,
[146] Fix | Delete
'message' => PPW_Constants::EMPTY_PASSWORD,
[147] Fix | Delete
),
[148] Fix | Delete
400
[149] Fix | Delete
);
[150] Fix | Delete
wp_die();
[151] Fix | Delete
}
[152] Fix | Delete
[153] Fix | Delete
$global_validate = ppw_free_check_duplicate_global_password( $new_global_passwords, $current_roles_password );
[154] Fix | Delete
if ( $global_validate ) {
[155] Fix | Delete
wp_send_json(
[156] Fix | Delete
array(
[157] Fix | Delete
'is_error' => true,
[158] Fix | Delete
'message' => PPW_Constants::DUPLICATE_PASSWORD,
[159] Fix | Delete
),
[160] Fix | Delete
400
[161] Fix | Delete
);
[162] Fix | Delete
wp_die();
[163] Fix | Delete
}
[164] Fix | Delete
}
[165] Fix | Delete
[166] Fix | Delete
/**
[167] Fix | Delete
* Check case duplicate password type is global
[168] Fix | Delete
*
[169] Fix | Delete
* @param $new_global_passwords
[170] Fix | Delete
* @param $current_roles_password
[171] Fix | Delete
*
[172] Fix | Delete
* @return bool
[173] Fix | Delete
*/
[174] Fix | Delete
function ppw_free_check_duplicate_global_password( $new_global_passwords, $current_roles_password ) {
[175] Fix | Delete
if ( empty( $current_roles_password ) ) {
[176] Fix | Delete
return false;
[177] Fix | Delete
}
[178] Fix | Delete
$password_duplicate = array_intersect( $new_global_passwords, array_values( $current_roles_password ) );
[179] Fix | Delete
[180] Fix | Delete
return ! empty( $password_duplicate );
[181] Fix | Delete
}
[182] Fix | Delete
[183] Fix | Delete
/**
[184] Fix | Delete
* Validate password type is role
[185] Fix | Delete
*
[186] Fix | Delete
* @param $role_selected
[187] Fix | Delete
* @param $new_role_password
[188] Fix | Delete
* @param $current_global_passwords
[189] Fix | Delete
* @param $current_roles_password
[190] Fix | Delete
*/
[191] Fix | Delete
function ppw_free_validate_password_type_role( $role_selected, $new_role_password, $current_global_passwords, $current_roles_password ) {
[192] Fix | Delete
if ( '' === $new_role_password && ( ! isset( $current_roles_password[ $role_selected ] ) || '' === $current_roles_password[ $role_selected ] ) ) {
[193] Fix | Delete
wp_send_json(
[194] Fix | Delete
array(
[195] Fix | Delete
'is_error' => true,
[196] Fix | Delete
'message' => PPW_Constants::EMPTY_PASSWORD,
[197] Fix | Delete
),
[198] Fix | Delete
400
[199] Fix | Delete
);
[200] Fix | Delete
wp_die();
[201] Fix | Delete
}
[202] Fix | Delete
[203] Fix | Delete
$role_validate = ppw_free_check_duplicate_role_password( $new_role_password, $current_global_passwords );
[204] Fix | Delete
if ( $role_validate ) {
[205] Fix | Delete
wp_send_json(
[206] Fix | Delete
array(
[207] Fix | Delete
'is_error' => true,
[208] Fix | Delete
'message' => PPW_Constants::DUPLICATE_PASSWORD,
[209] Fix | Delete
),
[210] Fix | Delete
400
[211] Fix | Delete
);
[212] Fix | Delete
wp_die();
[213] Fix | Delete
}
[214] Fix | Delete
}
[215] Fix | Delete
[216] Fix | Delete
/**
[217] Fix | Delete
* Check case duplicate password type is role
[218] Fix | Delete
*
[219] Fix | Delete
* @param $new_role_password
[220] Fix | Delete
* @param $current_global_passwords
[221] Fix | Delete
*
[222] Fix | Delete
* @return bool
[223] Fix | Delete
*/
[224] Fix | Delete
function ppw_free_check_duplicate_role_password( $new_role_password, $current_global_passwords ) {
[225] Fix | Delete
if ( empty( $current_global_passwords ) ) {
[226] Fix | Delete
return false;
[227] Fix | Delete
}
[228] Fix | Delete
$new_role_password = wp_unslash( $new_role_password );
[229] Fix | Delete
[230] Fix | Delete
return in_array( $new_role_password, $current_global_passwords );
[231] Fix | Delete
}
[232] Fix | Delete
[233] Fix | Delete
/**
[234] Fix | Delete
* Get all page and post
[235] Fix | Delete
*
[236] Fix | Delete
* @return array
[237] Fix | Delete
*/
[238] Fix | Delete
function ppw_free_get_all_page_post() {
[239] Fix | Delete
return array_merge( get_pages(), get_posts( array( 'post_status' => 'publish', 'numberposts' => - 1 ) ) );
[240] Fix | Delete
}
[241] Fix | Delete
[242] Fix | Delete
/**
[243] Fix | Delete
* Helper to fix serialized data
[244] Fix | Delete
* TODO: write UT for this important function
[245] Fix | Delete
*
[246] Fix | Delete
* @param $raw_data
[247] Fix | Delete
* @param $is_un_slashed
[248] Fix | Delete
*
[249] Fix | Delete
* @return array
[250] Fix | Delete
*/
[251] Fix | Delete
function ppw_free_fix_serialize_data( $raw_data, $is_un_slashed = true ) {
[252] Fix | Delete
if ( ! $raw_data ) {
[253] Fix | Delete
return array();
[254] Fix | Delete
}
[255] Fix | Delete
[256] Fix | Delete
if ( ! is_string( $raw_data ) ) {
[257] Fix | Delete
if ( is_array( $raw_data ) ) {
[258] Fix | Delete
return $raw_data;
[259] Fix | Delete
}
[260] Fix | Delete
[261] Fix | Delete
return array();
[262] Fix | Delete
}
[263] Fix | Delete
[264] Fix | Delete
[265] Fix | Delete
$serialize_raw_data = @unserialize( $raw_data );
[266] Fix | Delete
if ( false === $serialize_raw_data ) {
[267] Fix | Delete
return $raw_data;
[268] Fix | Delete
}
[269] Fix | Delete
[270] Fix | Delete
return $is_un_slashed ? wp_unslash( $serialize_raw_data ) : $serialize_raw_data;
[271] Fix | Delete
}
[272] Fix | Delete
[273] Fix | Delete
/**
[274] Fix | Delete
* @param $cookie
[275] Fix | Delete
* @param $expiration
[276] Fix | Delete
*
[277] Fix | Delete
* @return bool
[278] Fix | Delete
*/
[279] Fix | Delete
function ppw_free_bypass_cache_with_cookie_for_pro_version( $cookie, $expiration ) {
[280] Fix | Delete
if ( defined( 'COOKIEHASH' ) ) {
[281] Fix | Delete
$cookie_hash = preg_quote( constant( 'COOKIEHASH' ) );
[282] Fix | Delete
}
[283] Fix | Delete
setcookie( PPW_Constants::WP_POST_PASS . $cookie_hash, $cookie, $expiration, COOKIEPATH, COOKIE_DOMAIN );
[284] Fix | Delete
[285] Fix | Delete
return true;
[286] Fix | Delete
}
[287] Fix | Delete
[288] Fix | Delete
/**
[289] Fix | Delete
* Check custom login form is showing to avoid conflict with the_password_form default of WordPress.
[290] Fix | Delete
* - Check post type is default type ( post or page )
[291] Fix | Delete
* - Do not show login form product type because we handled it in PPW Pro version. ( woocommerce_before_single_product
[292] Fix | Delete
* hook )
[293] Fix | Delete
* - If Pro version is active then we check protection type in setting to show login form
[294] Fix | Delete
*
[295] Fix | Delete
* @param string $post_type Post Type of Post.
[296] Fix | Delete
*
[297] Fix | Delete
* @return bool True|False Is show login form.
[298] Fix | Delete
*/
[299] Fix | Delete
function ppw_is_post_type_selected_in_setting( $post_type ) {
[300] Fix | Delete
/**
[301] Fix | Delete
* Check default post type
[302] Fix | Delete
* Free & Pro version default: post and page type.
[303] Fix | Delete
*/
[304] Fix | Delete
if ( 'post' === $post_type || 'page' === $post_type ) {
[305] Fix | Delete
return true;
[306] Fix | Delete
}
[307] Fix | Delete
[308] Fix | Delete
$is_handle_old_product_type = apply_filters( PPW_Constants::HOOK_HANDLE_BEFORE_RENDER_WOO_PRODUCT, 'product' === $post_type, $post_type );
[309] Fix | Delete
if ( $is_handle_old_product_type || ! class_exists( 'PPW_Pro_Constants' ) ) {
[310] Fix | Delete
return false;
[311] Fix | Delete
}
[312] Fix | Delete
$post_type_selected = ppw_core_get_setting_type_array( PPW_Pro_Constants::WPP_WHITELIST_COLUMN_PROTECTIONS );
[313] Fix | Delete
[314] Fix | Delete
/**
[315] Fix | Delete
* Check post type in setting which user selected.
[316] Fix | Delete
*/
[317] Fix | Delete
return in_array( $post_type, $post_type_selected, true );
[318] Fix | Delete
}
[319] Fix | Delete
[320] Fix | Delete
/**
[321] Fix | Delete
* Get post_id from referer url if Post data is not exist post_id.
[322] Fix | Delete
*
[323] Fix | Delete
* @return int post_id Post ID, 0 if post id not exist.
[324] Fix | Delete
*/
[325] Fix | Delete
function ppw_get_post_id_from_request() {
[326] Fix | Delete
$_server = wp_unslash( $_SERVER );
[327] Fix | Delete
$_post = wp_unslash( $_POST ); // phpcs:ignore WordPress.Security.NonceVerification.Missing -- We no need to handle nonce verification for this function.
[328] Fix | Delete
if ( isset( $_post['post_id'] ) ) {
[329] Fix | Delete
return (int) wp_unslash( $_post['post_id'] );
[330] Fix | Delete
}
[331] Fix | Delete
/**
[332] Fix | Delete
* Make sure http referer on server.
[333] Fix | Delete
* Not make exception in url_to_postid.
[334] Fix | Delete
*/
[335] Fix | Delete
if ( ! isset( $_server['HTTP_REFERER'] ) ) {
[336] Fix | Delete
return 0;
[337] Fix | Delete
}
[338] Fix | Delete
[339] Fix | Delete
// Get post id from referer url.
[340] Fix | Delete
return url_to_postid( $_server['HTTP_REFERER'] );
[341] Fix | Delete
}
[342] Fix | Delete
[343] Fix | Delete
/**
[344] Fix | Delete
* WP introduced is_wp_version_compatible function from version 5.2.0 only.
[345] Fix | Delete
* (https://developer.wordpress.org/reference/functions/is_wp_version_compatible/)
[346] Fix | Delete
* Need to write the helper by our-self.
[347] Fix | Delete
*
[348] Fix | Delete
* @param string $required Version to check.
[349] Fix | Delete
*
[350] Fix | Delete
* @return bool
[351] Fix | Delete
*/
[352] Fix | Delete
function ppw_is_wp_version_compatible( $required ) {
[353] Fix | Delete
return empty( $required ) || version_compare( get_bloginfo( 'version' ), $required, '>=' );
[354] Fix | Delete
}
[355] Fix | Delete
[356] Fix | Delete
/**
[357] Fix | Delete
* Get page title for home, category, tag or post
[358] Fix | Delete
*
[359] Fix | Delete
* @return string
[360] Fix | Delete
*/
[361] Fix | Delete
function ppw_get_page_title() {
[362] Fix | Delete
$site_title = get_bloginfo( 'title' );
[363] Fix | Delete
$site_description = get_bloginfo( 'description' );
[364] Fix | Delete
$post_title = wp_title( '', false ); // Post title, category tile, tag title.
[365] Fix | Delete
$dash_score_site = '' === $site_title || '' === $site_description ? '' : ' – ';
[366] Fix | Delete
$dash_score_post = '' === $site_title || '' === $post_title ? '' : ' – ';
[367] Fix | Delete
[368] Fix | Delete
return is_home() || is_front_page()
[369] Fix | Delete
? sprintf( '%1$s%2$s%3$s', $site_title, $dash_score_site, $site_description )
[370] Fix | Delete
: sprintf( '%1$s%2$s%3$s', $post_title, $dash_score_post, $site_title );
[371] Fix | Delete
}
[372] Fix | Delete
[373] Fix | Delete
/**
[374] Fix | Delete
* Get post excerpt if post is protected via Settings.
[375] Fix | Delete
*
[376] Fix | Delete
* @param WP_Post $post Post WordPress Object.
[377] Fix | Delete
* @param string $content Content of post.
[378] Fix | Delete
* @param bool $is_show_excerpt Is show excerpt.
[379] Fix | Delete
* TODO: Need to refactor logic for this function.
[380] Fix | Delete
*
[381] Fix | Delete
* @return string
[382] Fix | Delete
*/
[383] Fix | Delete
function ppw_handle_protected_content( $post, $content, $is_show_excerpt ) {
[384] Fix | Delete
if ( $is_show_excerpt && $post->post_excerpt ) {
[385] Fix | Delete
$content = $post->post_excerpt . $content;
[386] Fix | Delete
}
[387] Fix | Delete
[388] Fix | Delete
if ( ! is_singular() && ! preg_match( '/name=.+post_id/mi', $content ) ) {
[389] Fix | Delete
$content = '<em>[This is password-protected.]</em>';
[390] Fix | Delete
[391] Fix | Delete
return apply_filters( 'the_ppw_password_message', $content );
[392] Fix | Delete
}
[393] Fix | Delete
[394] Fix | Delete
return $content;
[395] Fix | Delete
}
[396] Fix | Delete
[397] Fix | Delete
/**
[398] Fix | Delete
* Helper function to get Pro version.
[399] Fix | Delete
*/
[400] Fix | Delete
function ppw_get_pro_version() {
[401] Fix | Delete
if ( ! defined( 'PPW_PRO_VERSION' ) ) {
[402] Fix | Delete
return '';
[403] Fix | Delete
}
[404] Fix | Delete
[405] Fix | Delete
return PPW_PRO_VERSION;
[406] Fix | Delete
}
[407] Fix | Delete
[408] Fix | Delete
/**
[409] Fix | Delete
* Bypass function using to
[410] Fix | Delete
* - Display feed content when user turn on sitewide protection.
[411] Fix | Delete
*
[412] Fix | Delete
* @return bool True is bypass sitewide.
[413] Fix | Delete
*/
[414] Fix | Delete
function ppw_free_has_bypass_sitewide_protection() {
[415] Fix | Delete
$has_bypass = defined( 'PPWP_SITEWIDE_FEED_DISPLAY' ) && PPWP_SITEWIDE_FEED_DISPLAY && is_feed();
[416] Fix | Delete
[417] Fix | Delete
return apply_filters( 'ppwp_sitewide_has_bypass', $has_bypass );
[418] Fix | Delete
}
[419] Fix | Delete
[420] Fix | Delete
/**
[421] Fix | Delete
* Bypass function using to
[422] Fix | Delete
* - Display feed content when post/page is protected by single protection.
[423] Fix | Delete
*
[424] Fix | Delete
* @return bool True is bypass post_password_required.
[425] Fix | Delete
*/
[426] Fix | Delete
function ppw_free_has_bypass_single_protection() {
[427] Fix | Delete
$has_bypass = defined( 'PPWP_SINGLE_FEED_DISPLAY' ) && PPWP_SINGLE_FEED_DISPLAY && is_feed();
[428] Fix | Delete
[429] Fix | Delete
return apply_filters( 'ppwp_single_has_bypass', $has_bypass );
[430] Fix | Delete
}
[431] Fix | Delete
[432] Fix | Delete
/**
[433] Fix | Delete
* Has support PPWP shortcode for page builder.
[434] Fix | Delete
*
[435] Fix | Delete
* @return bool
[436] Fix | Delete
*/
[437] Fix | Delete
function ppw_free_has_support_shortcode_page_builder() {
[438] Fix | Delete
// Have user turn on option.
[439] Fix | Delete
$enabled = ppw_core_get_setting_type_bool_by_option_name( PPW_Constants::USE_SHORTCODE_PAGE_BUILDER, PPW_Constants::SHORTCODE_OPTIONS );
[440] Fix | Delete
[441] Fix | Delete
return apply_filters( 'ppwp_shortcode_enable_page_builder', $enabled );
[442] Fix | Delete
}
[443] Fix | Delete
[444] Fix | Delete
/**
[445] Fix | Delete
* Checks the plaintext password against the encrypted Password.
[446] Fix | Delete
*
[447] Fix | Delete
* @param string $password Plaintext user's password
[448] Fix | Delete
* @param string $hash Hash of the user's password to check against.
[449] Fix | Delete
*
[450] Fix | Delete
* @return bool False, if the $password does not match the hashed password
[451] Fix | Delete
* @link https://developer.wordpress.org/reference/functions/wp_check_password/
[452] Fix | Delete
*/
[453] Fix | Delete
function ppw_free_check_password( $password, $hash ) {
[454] Fix | Delete
/* global $wp_hasher;
[455] Fix | Delete
// If the stored hash is longer than an MD5,
[456] Fix | Delete
// presume the new style phpass portable hash.
[457] Fix | Delete
if ( empty( $wp_hasher ) ) {
[458] Fix | Delete
require_once ABSPATH . WPINC . '/class-phpass.php';
[459] Fix | Delete
// By default, use the portable hash from phpass.
[460] Fix | Delete
$wp_hasher = new PasswordHash( 8, true );
[461] Fix | Delete
}
[462] Fix | Delete
[463] Fix | Delete
return $wp_hasher->CheckPassword( $password, $hash );*/
[464] Fix | Delete
return wp_check_password( $password, $hash );
[465] Fix | Delete
[466] Fix | Delete
}
[467] Fix | Delete
[468] Fix | Delete
/**
[469] Fix | Delete
* Retrieve the shortcode matches for searching.
[470] Fix | Delete
*
[471] Fix | Delete
* @param $content
[472] Fix | Delete
*
[473] Fix | Delete
* @return array The regular expression contains 6 different sub matches to help with parsing.
[474] Fix | Delete
* 1 - An extra [ to allow for escaping shortcodes with double [[]]
[475] Fix | Delete
* 2 – The shortcode name
[476] Fix | Delete
* 3 – The shortcode argument list
[477] Fix | Delete
* 4 – The self closing /
[478] Fix | Delete
* 5 – The content of a shortcode when it wraps some content.
[479] Fix | Delete
* 6 – An extra ] to allow for escaping shortcodes with double [[]]
[480] Fix | Delete
*/
[481] Fix | Delete
function ppw_free_search_shortcode_content( $content ) {
[482] Fix | Delete
preg_match_all( '/' . get_shortcode_regex( array( 'ppwp' ) ) . '/', $content, $matches, PREG_SET_ORDER );
[483] Fix | Delete
[484] Fix | Delete
return $matches;
[485] Fix | Delete
}
[486] Fix | Delete
[487] Fix | Delete
function ppw_free_valid_pcp_password( $shortcode, $password ) {
[488] Fix | Delete
$default_args = array(
[489] Fix | Delete
'is_valid_password' => false,
[490] Fix | Delete
'atts' => array(),
[491] Fix | Delete
);
[492] Fix | Delete
// Check ppwp shortcode exist.
[493] Fix | Delete
if ( PPW_Constants::PPW_HOOK_SHORT_CODE_NAME !== $shortcode[2] || ! isset( $shortcode[3] ) ) {
[494] Fix | Delete
return $default_args;
[495] Fix | Delete
}
[496] Fix | Delete
// Parse shortcode string to array.
[497] Fix | Delete
$parsed_atts = shortcode_parse_atts( trim( $shortcode[3] ) );
[498] Fix | Delete
[499] Fix | Delete
12
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function