1009 lines
41 KiB
PHP
1009 lines
41 KiB
PHP
<?php
|
|
/**
|
|
* Functions Load
|
|
*
|
|
*/
|
|
|
|
// whitelist options, you can add more register_settings changing the second parameter
|
|
function wppb_register_settings() {
|
|
register_setting( 'wppb_option_group', 'wppb_default_settings' );
|
|
register_setting( 'wppb_general_settings', 'wppb_general_settings', 'wppb_general_settings_sanitize' );
|
|
register_setting( 'wppb_display_admin_settings', 'wppb_display_admin_settings' );
|
|
register_setting( 'wppb_profile_builder_pro_serial', 'wppb_profile_builder_pro_serial' );
|
|
register_setting( 'wppb_profile_builder_hobbyist_serial', 'wppb_profile_builder_hobbyist_serial' );
|
|
register_setting( 'wppb_module_settings', 'wppb_module_settings' );
|
|
register_setting( 'wppb_module_settings_description', 'wppb_module_settings_description' );
|
|
register_setting( 'customRedirectSettings', 'customRedirectSettings' );
|
|
register_setting( 'customUserListingSettings', 'customUserListingSettings' );
|
|
register_setting( 'reCaptchaSettings', 'reCaptchaSettings' );
|
|
register_setting( 'emailCustomizer', 'emailCustomizer' );
|
|
}
|
|
|
|
|
|
|
|
|
|
// WPML support
|
|
function wppb_icl_t($context, $name, $value){
|
|
if( function_exists( 'icl_t' ) )
|
|
return icl_t( $context, $name, $value );
|
|
|
|
else
|
|
return $value;
|
|
}
|
|
|
|
|
|
function wppb_add_plugin_stylesheet() {
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
|
|
if ( ( file_exists( WPPB_PLUGIN_DIR . '/assets/css/style-front-end.css' ) ) && ( isset( $wppb_generalSettings['extraFieldsLayout'] ) && ( $wppb_generalSettings['extraFieldsLayout'] == 'default' ) ) ){
|
|
wp_register_style( 'wppb_stylesheet', WPPB_PLUGIN_URL . 'assets/css/style-front-end.css', array(), PROFILE_BUILDER_VERSION );
|
|
wp_enqueue_style( 'wppb_stylesheet' );
|
|
}
|
|
if( is_rtl() ) {
|
|
if ( ( file_exists( WPPB_PLUGIN_DIR . '/assets/css/rtl.css' ) ) && ( isset( $wppb_generalSettings['extraFieldsLayout'] ) && ( $wppb_generalSettings['extraFieldsLayout'] == 'default' ) ) ){
|
|
wp_register_style( 'wppb_stylesheet_rtl', WPPB_PLUGIN_URL . 'assets/css/rtl.css', array(), PROFILE_BUILDER_VERSION );
|
|
wp_enqueue_style( 'wppb_stylesheet_rtl' );
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
function wppb_show_admin_bar($content){
|
|
global $current_user;
|
|
|
|
$adminSettingsPresent = get_option('wppb_display_admin_settings','not_found');
|
|
$show = null;
|
|
|
|
if ($adminSettingsPresent != 'not_found' && $current_user->ID)
|
|
foreach ($current_user->roles as $role_key) {
|
|
if (empty($GLOBALS['wp_roles']->roles[$role_key]))
|
|
continue;
|
|
$role = $GLOBALS['wp_roles']->roles[$role_key];
|
|
if (isset($adminSettingsPresent[$role['name']])) {
|
|
if ($adminSettingsPresent[$role['name']] == 'show')
|
|
$show = true;
|
|
if ($adminSettingsPresent[$role['name']] == 'hide' && $show === null)
|
|
$show = false;
|
|
}
|
|
}
|
|
return $show === null ? $content : $show;
|
|
}
|
|
|
|
|
|
if(!function_exists('wppb_curpageurl')){
|
|
function wppb_curpageurl() {
|
|
$pageURL = 'http';
|
|
|
|
if ((isset($_SERVER["HTTPS"])) && ($_SERVER["HTTPS"] == "on"))
|
|
$pageURL .= "s";
|
|
|
|
$pageURL .= "://";
|
|
|
|
if( strpos( $_SERVER["HTTP_HOST"], $_SERVER["SERVER_NAME"] ) !== false ){
|
|
$pageURL .=$_SERVER["HTTP_HOST"].$_SERVER["REQUEST_URI"];
|
|
}
|
|
else {
|
|
if ($_SERVER["SERVER_PORT"] != "80")
|
|
$pageURL .= $_SERVER["SERVER_NAME"] . ":" . $_SERVER["SERVER_PORT"] . $_SERVER["REQUEST_URI"];
|
|
else
|
|
$pageURL .= $_SERVER["SERVER_NAME"] . $_SERVER["REQUEST_URI"];
|
|
}
|
|
|
|
if ( function_exists('apply_filters') ) $pageURL = apply_filters('wppb_curpageurl', $pageURL);
|
|
|
|
return $pageURL;
|
|
}
|
|
}
|
|
|
|
|
|
if ( is_admin() ){
|
|
|
|
// register the settings for the menu only display sidebar menu for a user with a certain capability, in this case only the "admin"
|
|
add_action( 'admin_init', 'wppb_register_settings' );
|
|
|
|
// display the same extra profile fields in the admin panel also
|
|
if ( file_exists ( WPPB_PLUGIN_DIR.'/front-end/extra-fields/extra-fields.php' ) ){
|
|
require_once( WPPB_PLUGIN_DIR.'/front-end/extra-fields/extra-fields.php' );
|
|
|
|
add_action( 'show_user_profile', 'display_profile_extra_fields_in_admin', 10 );
|
|
add_action( 'edit_user_profile', 'display_profile_extra_fields_in_admin', 10 );
|
|
global $pagenow;
|
|
if( $pagenow != 'user-new.php' )
|
|
add_action( 'user_profile_update_errors', 'wppb_validate_backend_fields', 10, 3 );
|
|
add_action( 'personal_options_update', 'save_profile_extra_fields_in_admin', 10 );
|
|
add_action( 'edit_user_profile_update', 'save_profile_extra_fields_in_admin', 10 );
|
|
}
|
|
|
|
}else if ( !is_admin() ){
|
|
// include the stylesheet
|
|
add_action( 'wp_print_styles', 'wppb_add_plugin_stylesheet' );
|
|
|
|
// include the menu file for the profile informations
|
|
include_once( WPPB_PLUGIN_DIR.'/front-end/edit-profile.php' );
|
|
include_once( WPPB_PLUGIN_DIR.'/front-end/class-formbuilder.php' );
|
|
add_shortcode( 'wppb-edit-profile', 'wppb_front_end_profile_info' );
|
|
|
|
// include the menu file for the login screen
|
|
include_once( WPPB_PLUGIN_DIR.'/front-end/login.php' );
|
|
add_shortcode( 'wppb-login', 'wppb_front_end_login' );
|
|
|
|
// include the menu file for the logout screen
|
|
include_once( WPPB_PLUGIN_DIR.'/front-end/logout.php' );
|
|
add_shortcode( 'wppb-logout', 'wppb_front_end_logout' );
|
|
|
|
// include the menu file for the register screen
|
|
include_once( WPPB_PLUGIN_DIR.'/front-end/register.php' );
|
|
add_shortcode( 'wppb-register', 'wppb_front_end_register_handler' );
|
|
|
|
// include the menu file for the recover password screen
|
|
include_once( WPPB_PLUGIN_DIR.'/front-end/recover.php' );
|
|
add_shortcode( 'wppb-recover-password', 'wppb_front_end_password_recovery' );
|
|
|
|
// set the front-end admin bar to show/hide
|
|
add_filter( 'show_admin_bar' , 'wppb_show_admin_bar');
|
|
|
|
// Shortcodes used for the widget area
|
|
add_filter( 'widget_text', 'do_shortcode', 11 );
|
|
}
|
|
|
|
|
|
/**
|
|
* Function that overwrites the default wp_mail function and sends out emails
|
|
*
|
|
* @since v.2.0
|
|
*
|
|
* @param string $to
|
|
* @param string $subject
|
|
* @param string $message
|
|
* @param string $message_from
|
|
*
|
|
*/
|
|
function wppb_mail( $to, $subject, $message, $message_from = null, $context = null ) {
|
|
$to = apply_filters( 'wppb_send_email_to', $to );
|
|
$send_email = apply_filters( 'wppb_send_email', true, $to, $subject, $message, $context );
|
|
|
|
$message = apply_filters( 'wppb_email_message', $message, $context );
|
|
|
|
do_action( 'wppb_before_sending_email', $to, $subject, $message, $send_email, $context );
|
|
|
|
if ( $send_email ) {
|
|
//we add this filter to enable html encoding
|
|
add_filter( 'wp_mail_content_type', create_function( '', 'return "text/html"; ' ) );
|
|
|
|
$sent = wp_mail( $to , html_entity_decode( htmlspecialchars_decode( $subject, ENT_QUOTES ), ENT_QUOTES ), $message );
|
|
|
|
do_action( 'wppb_after_sending_email', $sent, $to, $subject, $message, $send_email, $context );
|
|
|
|
return $sent;
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
function wppb_activate_account_check(){
|
|
if ( ( isset( $_GET['activation_key'] ) ) && ( trim( $_GET['activation_key'] ) != '' ) ){
|
|
global $post;
|
|
$activation_key = sanitize_text_field( $_GET['activation_key'] );
|
|
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
$activation_landing_page_id = ( ( isset( $wppb_generalSettings['activationLandingPage'] ) && ( trim( $wppb_generalSettings['activationLandingPage'] ) != '' ) ) ? $wppb_generalSettings['activationLandingPage'] : 'not_set' );
|
|
|
|
if ( $activation_landing_page_id != 'not_set' ){
|
|
//an activation page was selected, but we still need to check if the current page doesn't already have the registration shortcode
|
|
if ( strpos( $post->post_content, '[wppb-register' ) === false )
|
|
add_filter( 'the_content', 'wppb_add_activation_message' );
|
|
|
|
}elseif ( strpos( $post->post_content, '[wppb-register' ) === false ){
|
|
//no activation page was selected, and the sent link pointed to the home url
|
|
wp_redirect( apply_filters( 'wppb_activatate_account_redirect_url', WPPB_PLUGIN_URL.'assets/misc/fallback-page.php?activation_key='.urlencode( $activation_key ).'&site_name='.urlencode( get_bloginfo( 'name' ) ).'&site_url='.urlencode( get_bloginfo( 'url' ) ).'&message='.urlencode( $activation_message = wppb_activate_signup( $activation_key ) ), $activation_key, $activation_message ) );
|
|
exit;
|
|
}
|
|
}
|
|
}
|
|
add_action( 'template_redirect', 'wppb_activate_account_check' );
|
|
|
|
|
|
function wppb_add_activation_message( $content ){
|
|
|
|
return wppb_activate_signup( sanitize_text_field( $_GET['activation_key'] ) ) . $content;
|
|
}
|
|
|
|
|
|
// Create a new, top-level page
|
|
$args = array(
|
|
'page_title' => 'Profile Builder',
|
|
'menu_title' => 'Profile Builder',
|
|
'capability' => 'manage_options',
|
|
'menu_slug' => 'profile-builder',
|
|
'page_type' => 'menu_page',
|
|
'position' => '70,69',
|
|
'priority' => 1,
|
|
'icon_url' => WPPB_PLUGIN_URL . 'assets/images/pb-menu-icon.png'
|
|
);
|
|
new WCK_Page_Creator_PB( $args );
|
|
|
|
/**
|
|
* Remove the automatically created submenu page
|
|
*
|
|
* @since v.2.0
|
|
*
|
|
* @return void
|
|
*/
|
|
function wppb_remove_main_menu_page(){
|
|
remove_submenu_page( 'profile-builder', 'profile-builder' );
|
|
}
|
|
add_action( 'admin_menu', 'wppb_remove_main_menu_page', 11 );
|
|
|
|
/**
|
|
* Add scripts to the back-end CPT's to remove the slug from the edit page
|
|
*
|
|
* @since v.2.0
|
|
*
|
|
* @return void
|
|
*/
|
|
function wppb_print_cpt_script( $hook ){
|
|
wp_enqueue_script( 'jquery-ui-dialog' );
|
|
wp_enqueue_style( 'wp-jquery-ui-dialog' );
|
|
|
|
if ( $hook == 'profile-builder_page_manage-fields' ){
|
|
wp_enqueue_script( 'wppb-manage-fields-live-change', WPPB_PLUGIN_URL . 'assets/js/jquery-manage-fields-live-change.js', array(), PROFILE_BUILDER_VERSION, true );
|
|
}
|
|
|
|
if (( $hook == 'profile-builder_page_manage-fields' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-basic-info' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-modules' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-general-settings' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-admin-bar-settings' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-register' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-wppb_userListing' ) ||
|
|
( $hook == 'profile-builder_page_custom-redirects' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-wppb_emailCustomizer' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-wppb_emailCustomizerAdmin' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-add-ons' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-woocommerce-sync' ) ||
|
|
( $hook == 'profile-builder_page_profile-builder-bbpress') ||
|
|
( $hook == 'admin_page_profile-builder-pms-promo') ) {
|
|
wp_enqueue_style( 'wppb-back-end-style', WPPB_PLUGIN_URL . 'assets/css/style-back-end.css', false, PROFILE_BUILDER_VERSION );
|
|
}
|
|
|
|
if ( $hook == 'profile-builder_page_profile-builder-general-settings' )
|
|
wp_enqueue_script( 'wppb-manage-fields-live-change', WPPB_PLUGIN_URL . 'assets/js/jquery-email-confirmation.js', array(), PROFILE_BUILDER_VERSION, true );
|
|
|
|
if( ($hook == 'profile-builder_page_profile-builder-add-ons' ) ||
|
|
($hook == 'admin_page_profile-builder-pms-promo' ) ) {
|
|
wp_enqueue_script('wppb-add-ons', WPPB_PLUGIN_URL . 'assets/js/jquery-pb-add-ons.js', array(), PROFILE_BUILDER_VERSION, true);
|
|
wp_enqueue_style( 'thickbox' );
|
|
wp_enqueue_script( 'thickbox' );
|
|
}
|
|
|
|
if ( isset( $_GET['post_type'] ) || isset( $_GET['post'] ) ){
|
|
if ( isset( $_GET['post_type'] ) )
|
|
$post_type = sanitize_text_field( $_GET['post_type'] );
|
|
|
|
elseif ( isset( $_GET['post'] ) )
|
|
$post_type = get_post_type( absint( $_GET['post'] ) );
|
|
|
|
if ( ( 'wppb-epf-cpt' == $post_type ) || ( 'wppb-rf-cpt' == $post_type ) || ( 'wppb-ul-cpt' == $post_type ) ){
|
|
wp_enqueue_style( 'wppb-back-end-style', WPPB_PLUGIN_URL . 'assets/css/style-back-end.css', false, PROFILE_BUILDER_VERSION );
|
|
wp_enqueue_script( 'wppb-epf-rf', WPPB_PLUGIN_URL . 'assets/js/jquery-epf-rf.js', array(), PROFILE_BUILDER_VERSION, true );
|
|
}
|
|
}
|
|
if ( file_exists ( WPPB_PLUGIN_DIR.'/update/update-checker.php' ) ) {
|
|
wp_enqueue_script( 'wppb-sitewide', WPPB_PLUGIN_URL . 'assets/js/jquery-pb-sitewide.js', array(), PROFILE_BUILDER_VERSION, true );
|
|
}
|
|
wp_enqueue_style( 'wppb-serial-notice-css', WPPB_PLUGIN_URL . 'assets/css/serial-notice.css', false, PROFILE_BUILDER_VERSION );
|
|
}
|
|
add_action( 'admin_enqueue_scripts', 'wppb_print_cpt_script' );
|
|
|
|
|
|
//the function used to overwrite the avatar across the wp installation
|
|
function wppb_changeDefaultAvatar( $avatar, $id_or_email, $size, $default, $alt ){
|
|
/* Get user info. */
|
|
if(is_object($id_or_email)){
|
|
$my_user_id = $id_or_email->user_id;
|
|
|
|
}elseif(is_numeric($id_or_email)){
|
|
$my_user_id = $id_or_email;
|
|
|
|
}elseif(!is_integer($id_or_email)){
|
|
$user_info = get_user_by( 'email', $id_or_email );
|
|
$my_user_id = ( is_object( $user_info ) ? $user_info->ID : '' );
|
|
}else
|
|
$my_user_id = $id_or_email;
|
|
|
|
$wppb_manage_fields = get_option( 'wppb_manage_fields', 'not_found' );
|
|
if ( $wppb_manage_fields != 'not_found' ){
|
|
foreach( $wppb_manage_fields as $value ){
|
|
if ( $value['field'] == 'Avatar'){
|
|
$avatar_field = $value;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* for multisite if we don't have an avatar try to get it from the main blog */
|
|
if( is_multisite() && empty( $avatar_field ) ){
|
|
switch_to_blog(1);
|
|
$wppb_switched_blog = true;
|
|
$wppb_manage_fields = get_option( 'wppb_manage_fields', 'not_found' );
|
|
if ( $wppb_manage_fields != 'not_found' ){
|
|
foreach( $wppb_manage_fields as $value ){
|
|
if ( $value['field'] == 'Avatar'){
|
|
$avatar_field = $value;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ( !empty( $avatar_field ) ){
|
|
|
|
$customUserAvatar = get_user_meta( $my_user_id, $avatar_field['meta-name'], true );
|
|
if( !empty( $customUserAvatar ) ){
|
|
if( is_numeric( $customUserAvatar ) ){
|
|
$img_attr = wp_get_attachment_image_src( $customUserAvatar, 'wppb-avatar-size-'.$size );
|
|
if( $img_attr[3] === false ){
|
|
$img_attr = wp_get_attachment_image_src( $customUserAvatar, 'thumbnail' );
|
|
$avatar = "<img alt='{$alt}' src='{$img_attr[0]}' class='avatar avatar-{$size} photo avatar-default' height='{$size}' width='{$size}' />";
|
|
}
|
|
else
|
|
$avatar = "<img alt='{$alt}' src='{$img_attr[0]}' class='avatar avatar-{$size} photo avatar-default' height='{$img_attr[2]}' width='{$img_attr[1]}' />";
|
|
}
|
|
else {
|
|
$customUserAvatar = get_user_meta($my_user_id, 'resized_avatar_' . $avatar_field['id'], true);
|
|
$customUserAvatarRelativePath = get_user_meta($my_user_id, 'resized_avatar_' . $avatar_field['id'] . '_relative_path', true);
|
|
|
|
if ((($customUserAvatar != '') || ($customUserAvatar != null)) && file_exists($customUserAvatarRelativePath)) {
|
|
$avatar = "<img alt='{$alt}' src='{$customUserAvatar}' class='avatar avatar-{$size} photo avatar-default' height='{$size}' width='{$size}' />";
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
/* if we switched the blog restore it */
|
|
if( is_multisite() && !empty( $wppb_switched_blog ) && $wppb_switched_blog )
|
|
restore_current_blog();
|
|
|
|
return $avatar;
|
|
}
|
|
add_filter( 'get_avatar', 'wppb_changeDefaultAvatar', 21, 5 );
|
|
|
|
|
|
//the function used to resize the avatar image; the new function uses a user ID as parameter to make pages load faster
|
|
function wppb_resize_avatar( $userID, $userlisting_size = null, $userlisting_crop = null ){
|
|
// include the admin image API
|
|
require_once( ABSPATH . '/wp-admin/includes/image.php' );
|
|
|
|
// retrieve first a list of all the current custom fields
|
|
$wppb_manage_fields = get_option( 'wppb_manage_fields', 'not_found' );
|
|
if ( $wppb_manage_fields != 'not_found' ){
|
|
foreach( $wppb_manage_fields as $value ){
|
|
if ( $value['field'] == 'Avatar'){
|
|
$avatar_field = $value;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* for multisite if we don't have an avatar try to get it from the main blog */
|
|
if( is_multisite() && empty( $avatar_field ) ){
|
|
switch_to_blog(1);
|
|
$wppb_switched_blog = true;
|
|
$wppb_manage_fields = get_option( 'wppb_manage_fields', 'not_found' );
|
|
if ( $wppb_manage_fields != 'not_found' ){
|
|
foreach( $wppb_manage_fields as $value ){
|
|
if ( $value['field'] == 'Avatar'){
|
|
$avatar_field = $value;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if ( !empty( $avatar_field ) ){
|
|
|
|
// retrieve width and height of the image
|
|
$width = $height = '';
|
|
|
|
//this checks if it only has 1 component
|
|
if ( is_numeric( $avatar_field['avatar-size'] ) ){
|
|
$width = $height = $avatar_field['avatar-size'];
|
|
|
|
}else{
|
|
//this checks if the entered value has 2 components
|
|
$sentValue = explode( ',', $avatar_field['avatar-size'] );
|
|
$width = $sentValue[0];
|
|
$height = $sentValue[1];
|
|
}
|
|
|
|
$width = ( !empty( $userlisting_size ) ? $userlisting_size : $width );
|
|
$height = ( !empty( $userlisting_size ) ? $userlisting_size : $height );
|
|
|
|
if( !strpos( get_user_meta( $userID, 'resized_avatar_'.$avatar_field['id'], true ), $width . 'x' . $height ) ) {
|
|
// retrieve the original image (in original size)
|
|
$avatar_directory_path = get_user_meta( $userID, 'avatar_directory_path_'.$avatar_field['id'], true );
|
|
|
|
$image = wp_get_image_editor( $avatar_directory_path );
|
|
if ( !is_wp_error( $image ) ) {
|
|
do_action( 'wppb_before_avatar_resizing', $image, $userID, $avatar_field['meta-name'], $avatar_field['avatar-size'] );
|
|
|
|
$crop = apply_filters( 'wppb_avatar_crop_resize', ( !empty( $userlisting_crop ) ? $userlisting_crop : false ) );
|
|
|
|
$resize = $image->resize( $width, $height, $crop );
|
|
|
|
if ($resize !== FALSE) {
|
|
do_action( 'wppb_avatar_resizing', $image, $resize );
|
|
|
|
$fileType = apply_filters( 'wppb_resized_file_extension', 'png' );
|
|
|
|
$wp_upload_array = wp_upload_dir(); // Array of key => value pairs
|
|
|
|
//create file(name); both with directory and url
|
|
$fileName_dir = $image->generate_filename( NULL, $wp_upload_array['basedir'].'/profile_builder/avatars/', $fileType );
|
|
|
|
if ( PHP_OS == "WIN32" || PHP_OS == "WINNT" )
|
|
$fileName_dir = str_replace( '\\', '/', $fileName_dir );
|
|
|
|
$fileName_url = str_replace( str_replace( '\\', '/', $wp_upload_array['basedir'] ), $wp_upload_array['baseurl'], $fileName_dir );
|
|
|
|
//save the newly created (resized) avatar on the disc
|
|
$saved_image = $image->save( $fileName_dir );
|
|
|
|
if ( !is_wp_error( $saved_image ) ) {
|
|
/* the image save sometimes doesn't save with the desired extension so we need to see with what extension it saved it with and
|
|
if it differs replace the extension in the path and url that we save as meta */
|
|
$validate_saved_image = wp_check_filetype_and_ext( $saved_image['path'], $saved_image['path'] );
|
|
$ext = substr( $fileName_dir,strrpos( $fileName_dir, '.', -1 ), strlen($fileName_dir) );
|
|
if( !empty( $validate_saved_image['ext'] ) && $validate_saved_image['ext'] != $ext ){
|
|
$fileName_url = str_replace( $ext, '.'.$validate_saved_image['ext'], $fileName_url );
|
|
$fileName_dir = str_replace( $ext, '.'.$validate_saved_image['ext'], $fileName_dir );
|
|
}
|
|
|
|
update_user_meta( $userID, 'resized_avatar_'.$avatar_field['id'], $fileName_url );
|
|
update_user_meta( $userID, 'resized_avatar_'.$avatar_field['id'].'_relative_path', $fileName_dir );
|
|
|
|
do_action( 'wppb_after_avatar_resizing', $image, $fileName_dir, $fileName_url );
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* if we switched the blog restore it */
|
|
if( is_multisite() && !empty( $wppb_switched_blog ) && $wppb_switched_blog )
|
|
restore_current_blog();
|
|
|
|
}
|
|
|
|
|
|
if ( is_admin() ){
|
|
// add a hook to delete the user from the _signups table if either the email confirmation is activated, or it is a wpmu installation
|
|
function wppb_delete_user_from_signups_table($user_id) {
|
|
global $wpdb;
|
|
|
|
$userLogin = $wpdb->get_var( $wpdb->prepare( "SELECT user_login, user_email FROM " . $wpdb->users . " WHERE ID = %d LIMIT 1", $user_id ) );
|
|
if ( is_multisite() )
|
|
$delete = $wpdb->delete( $wpdb->signups, array( 'user_login' => $userLogin ) );
|
|
else
|
|
$delete = $wpdb->delete( $wpdb->prefix.'signups', array( 'user_login' => $userLogin ) );
|
|
}
|
|
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if ( !empty( $wppb_generalSettings['emailConfirmation'] ) && ( $wppb_generalSettings['emailConfirmation'] == 'yes' ) ) {
|
|
if( is_multisite() )
|
|
add_action( 'wpmu_delete_user', 'wppb_delete_user_from_signups_table' );
|
|
else
|
|
add_action('delete_user', 'wppb_delete_user_from_signups_table');
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// This function offers compatibility with the all in one event calendar plugin
|
|
function wppb_aioec_compatibility(){
|
|
|
|
wp_deregister_script( 'jquery.tools-form');
|
|
}
|
|
add_action('admin_print_styles-users_page_ProfileBuilderOptionsAndSettings', 'wppb_aioec_compatibility');
|
|
|
|
|
|
function wppb_user_meta_exists( $id, $meta_name ){
|
|
global $wpdb;
|
|
|
|
return $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $wpdb->usermeta WHERE user_id = %d AND meta_key = %s", $id, $meta_name ) );
|
|
}
|
|
|
|
|
|
// function to check if there is a need to add the http:// prefix
|
|
function wppb_check_missing_http( $redirectLink ) {
|
|
return preg_match( '#^(?:[a-z\d]+(?:-+[a-z\d]+)*\.)+[a-z]+(?::\d+)?(?:/|$)#i', $redirectLink );
|
|
}
|
|
|
|
|
|
|
|
//function to output the password strength checker on frontend forms
|
|
function wppb_password_strength_checker_html(){
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if( !empty( $wppb_generalSettings['minimum_password_strength'] ) ){
|
|
$password_strength = '<span id="pass-strength-result">'.__('Strength indicator', 'profile-builder' ).'</span>
|
|
<input type="hidden" value="" name="wppb_password_strength" id="wppb_password_strength"/>';
|
|
return $password_strength;
|
|
}
|
|
return '';
|
|
}
|
|
|
|
//function to check password length check
|
|
function wppb_check_password_length( $password ){
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if( !empty( $wppb_generalSettings['minimum_password_length'] ) ){
|
|
if( strlen( $password ) < $wppb_generalSettings['minimum_password_length'] ){
|
|
return true;
|
|
}
|
|
else
|
|
return false;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
//function to check password strength
|
|
function wppb_check_password_strength(){
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if( isset( $_POST['wppb_password_strength'] ) && !empty( $wppb_generalSettings['minimum_password_strength'] ) ){
|
|
$wppb_password_strength = sanitize_text_field( $_POST['wppb_password_strength'] );
|
|
$password_strength_array = array( 'short' => 0, 'bad' => 1, 'good' => 2, 'strong' => 3 );
|
|
$password_strength_text = array( 'short' => __( 'Very Weak', 'profile-builder' ), 'bad' => __( 'Weak', 'profile-builder' ), 'good' => __( 'Medium', 'profile-builder' ), 'strong' => __( 'Strong', 'profile-builder' ) );
|
|
if( $password_strength_array[$wppb_password_strength] < $password_strength_array[$wppb_generalSettings['minimum_password_strength']] ){
|
|
return $password_strength_text[$wppb_generalSettings['minimum_password_strength']];
|
|
}
|
|
else
|
|
return false;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/* function to output password length requirements text */
|
|
function wppb_password_length_text(){
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if( !empty( $wppb_generalSettings['minimum_password_length'] ) ){
|
|
return sprintf(__('Minimum length of %d characters', 'profile-builder'), $wppb_generalSettings['minimum_password_length']);
|
|
}
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* Include password strength check scripts on frontend where we have shortoces present
|
|
*/
|
|
add_action( 'wp_footer', 'wppb_enqueue_password_strength_check' );
|
|
function wppb_enqueue_password_strength_check() {
|
|
global $wppb_shortcode_on_front;
|
|
if( $wppb_shortcode_on_front ){
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if( !empty( $wppb_generalSettings['minimum_password_strength'] ) ){
|
|
wp_enqueue_script( 'password-strength-meter' );
|
|
}
|
|
}
|
|
}
|
|
add_action( 'wp_footer', 'wppb_password_strength_check', 102 );
|
|
function wppb_password_strength_check(){
|
|
global $wppb_shortcode_on_front;
|
|
if( $wppb_shortcode_on_front ){
|
|
$wppb_generalSettings = get_option( 'wppb_general_settings' );
|
|
if( !empty( $wppb_generalSettings['minimum_password_strength'] ) ){
|
|
?>
|
|
<script type="text/javascript">
|
|
function check_pass_strength() {
|
|
var pass1 = jQuery('#passw1').val(), pass2 = jQuery('#passw2').val(), strength;
|
|
|
|
jQuery('#pass-strength-result').removeClass('short bad good strong');
|
|
if ( ! pass1 ) {
|
|
jQuery('#pass-strength-result').html( pwsL10n.empty );
|
|
return;
|
|
}
|
|
|
|
strength = wp.passwordStrength.meter( pass1, wp.passwordStrength.userInputBlacklist(), pass2 );
|
|
|
|
switch ( strength ) {
|
|
case 2:
|
|
jQuery('#pass-strength-result').addClass('bad').html( pwsL10n.bad );
|
|
jQuery('#wppb_password_strength').val('bad');
|
|
break;
|
|
case 3:
|
|
jQuery('#pass-strength-result').addClass('good').html( pwsL10n.good );
|
|
jQuery('#wppb_password_strength').val('good');
|
|
break;
|
|
case 4:
|
|
jQuery('#pass-strength-result').addClass('strong').html( pwsL10n.strong );
|
|
jQuery('#wppb_password_strength').val('strong');
|
|
break;
|
|
case 5:
|
|
jQuery('#pass-strength-result').addClass('short').html( pwsL10n.mismatch );
|
|
jQuery('#wppb_password_strength').val('short');
|
|
break;
|
|
default:
|
|
jQuery('#pass-strength-result').addClass('short').html( pwsL10n['short'] );
|
|
jQuery('#wppb_password_strength').val('short');
|
|
}
|
|
}
|
|
jQuery( document ).ready( function() {
|
|
// Binding to trigger checkPasswordStrength
|
|
jQuery('#passw1').val('').keyup( check_pass_strength );
|
|
jQuery('#passw2').val('').keyup( check_pass_strength );
|
|
jQuery('#pass-strength-result').show();
|
|
});
|
|
</script>
|
|
<?php
|
|
}
|
|
}
|
|
}
|
|
/**
|
|
* Create functions for repeating error messages in front-end forms
|
|
*/
|
|
function wppb_required_field_error($field_title='') {
|
|
$required_error = apply_filters('wppb_required_error' , __('This field is required','profile-builder') , $field_title);
|
|
|
|
return $required_error;
|
|
|
|
}
|
|
|
|
/**
|
|
* Function that returns a certain field (from manage_fields) by a given id or meta_name
|
|
*/
|
|
function wppb_get_field_by_id_or_meta( $id_or_meta ){
|
|
|
|
$id = 0;
|
|
$meta = '';
|
|
|
|
if ( is_numeric($id_or_meta) )
|
|
$id = $id_or_meta;
|
|
else
|
|
$meta = $id_or_meta;
|
|
|
|
$fields = get_option('wppb_manage_fields', 'not_found');
|
|
|
|
if ($fields != 'not_found') {
|
|
|
|
foreach ($fields as $key => $field) {
|
|
if ( (!empty($id)) && ($field['id'] == $id) )
|
|
return $field;
|
|
if ( (!empty($meta)) && ($field['meta-name'] == $meta) )
|
|
return $field;
|
|
}
|
|
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
|
|
/* Function for displaying reCAPTCHA error on Login and Recover Password forms */
|
|
function wppb_recaptcha_field_error($field_title='') {
|
|
$recaptcha_error = apply_filters('wppb_recaptcha_error' , __('Please enter a (valid) reCAPTCHA value','profile-builder') , $field_title);
|
|
|
|
return $recaptcha_error;
|
|
|
|
}
|
|
/* Function for displaying phone field error */
|
|
function wppb_phone_field_error( $field_title = '' ) {
|
|
$phone_error = apply_filters( 'wppb_phone_error' , __( 'Incorrect phone number', 'profile-builder' ) , $field_title );
|
|
|
|
return $phone_error;
|
|
}
|
|
|
|
/* Create a wrapper function for get_query_var */
|
|
function wppb_get_query_var( $varname ){
|
|
return apply_filters( 'wppb_get_query_var_'.$varname, get_query_var( $varname ) );
|
|
}
|
|
|
|
/* Filter the "Save Changes" button text, to make it translatable */
|
|
function wppb_change_save_changes_button($value){
|
|
$value = __('Save Changes','profile-builder');
|
|
return $value;
|
|
}
|
|
add_filter( 'wck_save_changes_button', 'wppb_change_save_changes_button', 10, 2);
|
|
|
|
/* Filter the "Cancel" button text, to make it translatable */
|
|
function wppb_change_cancel_button($value){
|
|
$value = __('Cancel','profile-builder');
|
|
return $value;
|
|
}
|
|
add_filter( 'wck_cancel_button', 'wppb_change_cancel_button', 10, 2);
|
|
|
|
/* ilter the "Delete" button text, to make it translatable */
|
|
function wppb_change_delete_button($value){
|
|
$value = __('Delete','profile-builder');
|
|
return $value;
|
|
}
|
|
add_filter( 'wck_delete_button', 'wppb_change_delete_button', 10, 2);
|
|
|
|
/*Filter the "Edit" button text, to make it translatable*/
|
|
function wppb_change_edit_button($value){
|
|
$value = __('Edit','profile-builder');
|
|
return $value;
|
|
}
|
|
add_filter( 'wck_edit_button', 'wppb_change_edit_button', 10, 2);
|
|
|
|
/*Filter the User Listing, Register Forms and Edit Profile forms metabox header content, to make it translatable*/
|
|
function wppb_change_metabox_content_header(){
|
|
return '<thead><tr><th class="wck-number">#</th><th class="wck-content">'. __( 'Content', 'profile-builder' ) .'</th><th class="wck-edit">'. __( 'Edit', 'profile-builder' ) .'</th><th class="wck-delete">'. __( 'Delete', 'profile-builder' ) .'</th></tr></thead>';
|
|
}
|
|
add_filter('wck_metabox_content_header_wppb_ul_page_settings', 'wppb_change_metabox_content_header', 1);
|
|
add_filter('wck_metabox_content_header_wppb_rf_page_settings', 'wppb_change_metabox_content_header', 1);
|
|
add_filter('wck_metabox_content_header_wppb_epf_page_settings', 'wppb_change_metabox_content_header', 1);
|
|
|
|
|
|
/* Add a notice if people are not able to register via Profile Builder; Membership -> "Anyone can register" checkbox is not checked under WordPress admin UI -> Settings -> General tab */
|
|
if ( (get_option('users_can_register') == false) && (!class_exists('PMS_Add_General_Notices')) ) {
|
|
if( is_multisite() ) {
|
|
new WPPB_Add_General_Notices('wppb_anyone_can_register',
|
|
sprintf(__('To allow users to register for your website via Profile Builder, you first must enable user registration. Go to %1$sNetwork Settings%2$s, and under Registration Settings make sure to check “User accounts may be registered”. %3$sDismiss%4$s', 'profile-builder'), "<a href='" . network_admin_url('settings.php') . "'>", "</a>", "<a href='" . esc_url( add_query_arg('wppb_anyone_can_register_dismiss_notification', '0') ) . "'>", "</a>"),
|
|
'update-nag');
|
|
}else{
|
|
new WPPB_Add_General_Notices('wppb_anyone_can_register',
|
|
sprintf(__('To allow users to register for your website via Profile Builder, you first must enable user registration. Go to %1$sSettings -> General%2$s tab, and under Membership make sure to check “Anyone can register”. %3$sDismiss%4$s', 'profile-builder'), "<a href='" . admin_url('options-general.php') . "'>", "</a>", "<a href='" . esc_url( add_query_arg('wppb_anyone_can_register_dismiss_notification', '0') ) . "'>", "</a>"),
|
|
'update-nag');
|
|
}
|
|
}
|
|
|
|
/*Filter default WordPress notices ("Post published. Post updated."), add post type name for User Listing, Registration Forms and Edit Profile Forms*/
|
|
function wppb_change_default_post_updated_messages($messages){
|
|
global $post;
|
|
$post_type = get_post_type($post->ID);
|
|
$object = get_post_type_object($post_type);
|
|
|
|
if ( ($post_type == 'wppb-rf-cpt')||($post_type == 'wppb-epf-cpt')||($post_type == 'wppb-ul-cpt') ){
|
|
$messages['post'][1] = $object->labels->name . ' updated.';
|
|
$messages['post'][6] = $object->labels->name . ' published.';
|
|
}
|
|
return $messages;
|
|
}
|
|
add_filter('post_updated_messages','wppb_change_default_post_updated_messages', 2);
|
|
|
|
|
|
/* for meta-names with spaces in them PHP converts the space to underline in the $_POST */
|
|
function wppb_handle_meta_name( $meta_name ){
|
|
$meta_name = str_replace( ' ', '_', $meta_name );
|
|
$meta_name = str_replace( '.', '_', $meta_name );
|
|
return $meta_name;
|
|
}
|
|
|
|
|
|
// change User Registered date and time according to timezone selected in WordPress settings
|
|
function wppb_get_date_by_timezone() {
|
|
$wppb_wp_timezone = get_option( 'timezone_string' );
|
|
|
|
if( ! empty( $wppb_wp_timezone ) ) {
|
|
date_default_timezone_set( $wppb_wp_timezone );
|
|
$wppb_get_date = date( "Y-m-d G:i:s" );
|
|
} else {
|
|
$wppb_wp_gmt_offset = get_option( 'gmt_offset' );
|
|
$wppb_gmt_offset = $wppb_wp_gmt_offset * 60 * 60;
|
|
$wppb_get_date = gmdate( "Y-m-d G:i:s", time() + $wppb_gmt_offset );
|
|
}
|
|
|
|
return $wppb_get_date;
|
|
}
|
|
|
|
/**
|
|
* Add HTML tag 'required' to fields
|
|
*
|
|
* Add HTML tag 'required' for each field if the field is required. For browsers that don't support this HTML tag, we will still have the fallback.
|
|
* Field type 'Checkbox' is explicitly excluded because there is no HTML support to check if at least one option is selected.
|
|
* Other fields excluded are Avatar, Upload, Heading, ReCaptcha, WYSIWYG, Map.
|
|
*
|
|
* @since
|
|
*
|
|
* @param string $extra_attributes Extra attributes attached to the field HTML tag.
|
|
* @param array $field Field description.
|
|
* @return string $extra_attributes
|
|
*/
|
|
function wppb_add_html_tag_required_to_fields( $extra_attributes, $field, $form_location ) {
|
|
if ( $field['field'] != "Checkbox" && isset( $field['required'] ) && $field['required'] == 'Yes' ){
|
|
if( !( ( $field['field'] == "Default - Password" || $field['field'] == "Default - Repeat Password" ) && $form_location == 'edit_profile' ) )
|
|
$extra_attributes .= ' required ';
|
|
}
|
|
return $extra_attributes;
|
|
}
|
|
add_filter( 'wppb_extra_attribute', 'wppb_add_html_tag_required_to_fields', 10, 3 );
|
|
|
|
/**
|
|
* Add HTML tag 'required' to WooCommerce fields
|
|
*
|
|
* Add HTML tag 'required' for each WooCommerce field if the field is required. For browsers that don't support this HTML tag, we will still have the fallback.
|
|
* Does not work on 'State / County' field, if it becomes required later depending on the Country Value
|
|
*
|
|
* @since
|
|
*
|
|
* @param string $extra_attributes Extra attributes attached to the field HTML tag.
|
|
* @param array $field Field description.
|
|
* @return string $extra_attributes
|
|
*/
|
|
function wppb_add_html_tag_required_to_woo_fields( $extra_attributes, $field ) {
|
|
if ( isset( $field['required'] ) && $field['required'] == 'Yes' ){
|
|
$extra_attributes .= ' required ';
|
|
}
|
|
return $extra_attributes;
|
|
}
|
|
add_filter( 'wppb_woo_extra_attribute', 'wppb_add_html_tag_required_to_woo_fields', 10, 2 );
|
|
|
|
|
|
/**
|
|
* Add jQuery script to remove required attribute for hidden fields
|
|
*
|
|
* If a field is hidden dynamically via conditional fields or WooSync 'Ship to a different address' checkbox, then the required field needs to be removed.
|
|
* If a field is made visible again, add the required field back again.
|
|
*
|
|
* @since
|
|
*
|
|
* @param string $extra_attributes Extra attributes attached to the field HTML tag.
|
|
* @param array $field Field description.
|
|
* @return string $extra_attributes
|
|
*/
|
|
function wppb_manage_required_attribute() {
|
|
global $wppb_shortcode_on_front;
|
|
if ($wppb_shortcode_on_front) {
|
|
?>
|
|
<script type="text/javascript">
|
|
jQuery(document).on( "wppbAddRequiredAttributeEvent", wppbAddRequired );
|
|
function wppbAddRequired(event) {
|
|
var element = wppbEventTargetRequiredElement( event.target );
|
|
if( jQuery( element ).attr( "wppb_cf_temprequired" ) ){
|
|
jQuery( element ).removeAttr( "wppb_cf_temprequired" );
|
|
jQuery( element ).attr( "required", "required" );
|
|
}
|
|
}
|
|
|
|
jQuery(document).on( "wppbRemoveRequiredAttributeEvent", wppbRemoveRequired );
|
|
function wppbRemoveRequired(event) {
|
|
var element = wppbEventTargetRequiredElement( event.target );
|
|
if ( jQuery( element ).attr( "required" ) ) {
|
|
jQuery( element ).removeAttr( "required" );
|
|
jQuery( element ).attr( "wppb_cf_temprequired", "wppb_cf_temprequired" );
|
|
}
|
|
}
|
|
|
|
jQuery(document).on( "wppbToggleRequiredAttributeEvent", wppbToggleRequired );
|
|
function wppbToggleRequired(event) {
|
|
if ( jQuery( event.target ).attr( "required" ) ) {
|
|
jQuery( event.target ).removeAttr( "required" );
|
|
jQuery( event.target ).attr( "wppb_cf_temprequired", "wppb_cf_temprequired" );
|
|
}else if( jQuery( event.target ).attr( "wppb_cf_temprequired" ) ){
|
|
jQuery( event.target ).removeAttr( "wppb_cf_temprequired" );
|
|
jQuery( event.target ).attr( "required", "required" );
|
|
}
|
|
}
|
|
|
|
function wppbEventTargetRequiredElement( htmlElement ){
|
|
if ( htmlElement.nodeName == "OPTION" ){
|
|
// <option> is the target element, so we need to get the parent <select>, in order to apply the required attribute
|
|
return htmlElement.parentElement;
|
|
}else{
|
|
return htmlElement;
|
|
}
|
|
}
|
|
|
|
</script>
|
|
<?php
|
|
}
|
|
}
|
|
add_action( 'wp_footer', 'wppb_manage_required_attribute' );
|
|
|
|
function wpbb_specify_blog_details_on_signup_email( $message, $user_email, $user, $activation_key, $registration_page_url, $meta, $from_name, $context ){
|
|
$meta = unserialize($meta);
|
|
|
|
if ( is_multisite() && isset( $meta['wppb_create_new_site_checkbox'] ) && $meta['wppb_create_new_site_checkbox'] == 'yes' ) {
|
|
$blog_details = wpmu_validate_blog_signup( $meta['wppb_blog_url'], $meta['wppb_blog_title'] );
|
|
|
|
if ( empty($blog_details['errors']->errors['blogname']) && empty($blog_details['errors']->errors['blog_title'])) {
|
|
$blog_path = $blog_details['domain'] . $blog_details['path'];
|
|
$message .= __( '<br><br>Also, you will be able to visit your site at ', 'profile-builder' ) . '<a href="' . $blog_path . '">' . $blog_path . '</a>.';
|
|
}
|
|
}
|
|
return $message;
|
|
}
|
|
add_filter( 'wppb_signup_user_notification_email_content', 'wpbb_specify_blog_details_on_signup_email', 5, 8 );
|
|
|
|
function wpbb_specify_blog_details_on_registration_email( $user_message_content, $email, $password, $user_message_subject, $context ){
|
|
|
|
if ( is_multisite() ) {
|
|
$user = get_user_by( 'email', $email );
|
|
$blog_path = wppb_get_blog_url_of_user_id( $user->ID );
|
|
if ( ! empty ( $blog_path ) ) {
|
|
$user_message_content .= __( '<br><br>You can visit your site at ', 'profile-builder' ) . '<a href="' . $blog_path . '">' . $blog_path . '</a>.';
|
|
}
|
|
}
|
|
return $user_message_content;
|
|
|
|
}
|
|
add_filter( 'wppb_register_user_email_message_without_admin_approval', 'wpbb_specify_blog_details_on_registration_email', 5, 5 );
|
|
add_filter( 'wppb_register_user_email_message_with_admin_approval', 'wpbb_specify_blog_details_on_registration_email', 5, 5 );
|
|
|
|
|
|
function wppb_get_blog_url_of_user_id( $user_id, $ignore_privacy = true ){
|
|
$blog_id = get_user_meta( $user_id, 'primary_blog', true );
|
|
if ( is_multisite() && !empty( $blog_id ) ){
|
|
$blog_details = get_blog_details( $blog_id );
|
|
if ( $ignore_privacy || $blog_details->public ) {
|
|
return $blog_details->domain . $blog_details->path;
|
|
}
|
|
}
|
|
return '';
|
|
}
|
|
|
|
function wppb_can_users_signup_blog(){
|
|
if ( ! is_multisite() )
|
|
return false;
|
|
global $wpdb;
|
|
$current_site = get_current_site();
|
|
$sitemeta_options_query = $wpdb->prepare( "SELECT meta_value FROM {$wpdb->sitemeta} WHERE meta_key = 'registration' AND site_id = %d", $current_site->id );
|
|
$network_options_meta = $wpdb->get_results( $sitemeta_options_query );
|
|
|
|
if ( $network_options_meta[0]->meta_value == 'all' ){
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Function that handle redirect URL
|
|
*
|
|
* @param string $redirect_priority - it can be normal or top priority
|
|
* @param string $redirect_type - type of the redirect
|
|
* @param null|string $redirect_url - redirect URL if already set
|
|
* @param null|string|object $user - username, user email or user data
|
|
* @param null|string $user_role - user role
|
|
*
|
|
* @return null|string $redirect_url
|
|
*/
|
|
function wppb_get_redirect_url( $redirect_priority = 'normal', $redirect_type, $redirect_url = NULL, $user = NULL, $user_role = NULL ) {
|
|
if( PROFILE_BUILDER == 'Profile Builder Pro' ) {
|
|
$wppb_module_settings = get_option( 'wppb_module_settings' );
|
|
|
|
if( isset( $wppb_module_settings['wppb_customRedirect'] ) && $wppb_module_settings['wppb_customRedirect'] == 'show' && $redirect_priority != 'top' && function_exists( 'wppb_custom_redirect_url' ) ) {
|
|
$redirect_url = wppb_custom_redirect_url( $redirect_type, $redirect_url, $user, $user_role );
|
|
}
|
|
}
|
|
|
|
if( ! empty( $redirect_url ) ) {
|
|
$redirect_url = ( wppb_check_missing_http( $redirect_url ) ? 'http://'. $redirect_url : $redirect_url );
|
|
}
|
|
|
|
return $redirect_url;
|
|
}
|
|
|
|
/**
|
|
* Function that builds the redirect
|
|
*
|
|
* @param string $redirect_url - redirect URL
|
|
* @param int $redirect_delay - redirect delay in seconds
|
|
* @param null|string $redirect_type - the type of the redirect
|
|
* @param null|array $form_args - form args if set
|
|
*
|
|
* @return string $redirect_message
|
|
*/
|
|
function wppb_build_redirect( $redirect_url, $redirect_delay, $redirect_type = NULL, $form_args = NULL ) {
|
|
if( isset( $redirect_type ) ) {
|
|
$redirect_url = apply_filters( 'wppb_'. $redirect_type .'_redirect', $redirect_url );
|
|
}
|
|
|
|
$redirect_message = '';
|
|
|
|
if( ! empty( $redirect_url ) ) {
|
|
$redirect_url = ( wppb_check_missing_http( $redirect_url ) ? 'http://'. $redirect_url : $redirect_url );
|
|
|
|
if( $redirect_delay == 0 ) {
|
|
$redirect_message = '<meta http-equiv="Refresh" content="'. $redirect_delay .';url='. $redirect_url .'" />';
|
|
} else {
|
|
$redirect_url_href = apply_filters( 'wppb_redirect_url', '<a href="'. $redirect_url .'">'. __( 'here', 'profile-builder' ) .'</a>', $redirect_url, $redirect_type, $form_args );
|
|
$redirect_message = apply_filters( 'wppb_redirect_message_before_returning', '<p class="redirect_message">'. sprintf( wp_slash( __( 'You will soon be redirected automatically. If you see this page for more than %1$d seconds, please click %2$s.%3$s', 'profile-builder' ) ), $redirect_delay, $redirect_url_href, '<meta http-equiv="Refresh" content="'. $redirect_delay .';url='. $redirect_url .'" />' ) .'</p>', $redirect_url, $redirect_delay, $redirect_url_href, $redirect_type, $form_args );
|
|
}
|
|
}
|
|
|
|
return $redirect_message;
|
|
}
|
|
|
|
/**
|
|
* Function that strips the script tags from an input
|
|
* @param $string
|
|
* @return mixed
|
|
*/
|
|
function wppb_sanitize_value( $string ){
|
|
return preg_replace( '/<script\b[^>]*>(.*?)<\/script>/is', '', $string );
|
|
}
|