HEX
Server: Apache/2
System: Linux server.vm113-cu.cl1.il.proginter.com 4.18.0-553.78.1.el8_10.x86_64 #1 SMP Tue Oct 7 04:15:13 EDT 2025 x86_64
User: regevl (1053)
PHP: 7.4.33
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/regevl/domains/to-web.co.il/public_html/my/wp-content/plugins/wp-socializer/admin/admin.php
<?php
/**
  * Main entry point class for admin page
  * 
  **/

defined( 'ABSPATH' ) || exit;

class WPSR_Admin{
    
    public static $pages = array();
    public static $pagehook = 'toplevel_page_wp_socializer';
    public static $current_page = 'home';
    
    public static function init(){
        
        // Register the admin pages
        add_action( 'init', array( __CLASS__, 'register_pages' ) );

        // Register the admin menu
        add_action( 'admin_menu', array( __CLASS__, 'admin_menu' ) );

        // Enqueue the scripts and styles
        add_action( 'admin_enqueue_scripts', array( __CLASS__, 'enqueue_scripts' ) );

        // Register action to include admin scripts
        add_action( 'admin_print_scripts', array( __CLASS__, 'inline_scripts' ) );

        // Register the action for admin ajax features
        add_action( 'wp_ajax_wpsr_admin_ajax', array( __CLASS__, 'admin_ajax' ) );

        // Register the action links in plugin list page
        add_filter( 'plugin_action_links_' . WPSR_BASE_NAME, array( __CLASS__, 'action_links' ) );

        add_action( 'plugins_loaded', array( __CLASS__, 'on_activate' ) );

        add_filter( 'admin_footer_text', array( __class__, 'footer_text' ) );

        register_activation_hook( WPSR_BASE_NAME, array( __CLASS__, 'on_activate' ) );

    }
    
    public static function register_pages(){
        
        $init_pages = apply_filters( 'wpsr_register_admin_page', array() );
        $defaults = array(
            'name' => '',
            'banner' => '',
            'description' => '',
            'category' => '',
            'type' => '',
            'form_name' => '',
            'callbacks' => array(
                'page' => false,
                'form' => false,
                'validation' => false,
            )
        );
        
        foreach( $init_pages as $id => $config ){

            $config = WPSR_Lists::set_defaults( $config, $defaults );
            self::$pages[ $id ] = $config;

            // Register the validation filter for the form
            if( $config[ 'callbacks' ][ 'validation' ] ){
                add_filter( 'wpsr_form_validation_' . $config[ 'form_name' ], $config[ 'callbacks' ][ 'validation' ] );
            }
            
        }
        
    }

    public static function get_pages(){
        return apply_filters( 'wpsr_mod_admin_pages', self::$pages );
    }

    public static function admin_menu(){
        
        $pages = self::get_pages();
        $icon = WPSR_ADMIN_URL . 'images/icons/wp-socializer-sm.png';
        
        add_menu_page( 'WP Socializer - Admin page', 'WP Socializer', 'manage_options', 'wp_socializer', array( __CLASS__, 'admin_page' ), $icon );
        
        add_submenu_page( 'wp_socializer', 'WP Socializer - Admin page', 'Home', 'manage_options', 'wp_socializer', array( __CLASS__, 'admin_page' ) );
        
        foreach( $pages as $id => $config ){
            if( empty( $config[ 'link' ] ) ){
                add_submenu_page( 'wp_socializer', 'WP Socializer - ' . $config[ 'name' ], $config[ 'name' ], 'manage_options', 'wp_socializer&tab="' . sanitize_key( $id ) . '"', array( __CLASS__, 'admin_page' ) );
            }
        }

        add_submenu_page( 'wp_socializer', 'WP Socializer - Upgrade', '<span style="color: gold">Upgrade</span>', 'manage_options', 'https://www.aakashweb.com/wordpress-plugins/wp-socializer/?utm_source=admin&utm_medium=menu&utm_campaign=wpsr-pro#pro', null );

    }

    public static function admin_page(){

        if( !current_user_can( 'manage_options' ) ){
            wp_die( __( 'You do not have sufficient permissions to access this page.' ) );
        }

        $pages = self::get_pages();
        self::$current_page = isset( $_GET['tab'] ) ? sanitize_text_field( $_GET['tab'] ) : '';

        // Set default page
        if( empty( self::$current_page ) || !array_key_exists( self::$current_page, $pages ) ){
            self::$current_page = 'home';
        }

        echo '<div class="wrap page_' . esc_attr( self::$current_page ) . '">';

            self::admin_header();

            echo '<div id="main">';
                self::admin_content();
                self::admin_sidebar();
            echo '</div>';

        echo '</div>';

        self::intro_popups();

    }

    public static function admin_header(){
        
        echo '<header id="wpsr_header">';
        echo '<hgroup>';
        echo '<h1 class="wpsr_title">WP Socializer 
        <span class="title-count">' . WPSR_VERSION . '</span><a href="admin.php?page=wp_socializer" class="back_btn"><i class="fa fa-chevron-left"></i> Back</a></h1>';
        self::admin_links();
        echo '</hgroup>';
        echo '</header>';
        
    }
    
    public static function admin_content(){

        $pages = self::get_pages();

        echo '<div id="content">';

        if(self::$current_page == 'home'){

            echo '<h1>Features</h1>';
            self::admin_pages_list( 'feature' );

            echo '<h1>Sidebar Widgets</h1>';
            self::admin_pages_list( 'widget' );

            echo '<h1>Settings</h1>';
            self::admin_pages_list( 'other' );

            self::pro_promo_box();

        }else{

            $page = $pages[ self::$current_page ];
            echo '<div class="page_head">';
            echo '<h1>' . esc_html( $page[ 'name' ] ) . '</h1>';
            if( !empty( $page[ 'description' ] ) ) echo '<p>' . esc_html( $page[ 'description' ] ) . '</p>';
            echo '</div>';

            call_user_func( $pages[ self::$current_page ][ 'callbacks' ][ 'page' ] );
        }

        echo '</div>';

    }

    public static function admin_pages_list( $category = false ){

        $pages = self::get_pages();

        echo '<div class="admin_pages_list">';

        foreach( $pages as $id => $config ){
            
            if( $config[ 'category' ] != $category ){
                continue;
            }

            $is_feature_active = false;
            $action_text = __( 'Open', 'wp-socializer' );
            $link = empty( $config['link'] ) ? ( 'admin.php?page=wp_socializer&tab=' . $id ) : $config[ 'link' ];

            if( $config[ 'type' ] == 'feature' ){
                $feat_settings = get_option( 'wpsr_' . $config['form_name'], array() );
                $feat_settings = WPSR_Lists::set_defaults( $feat_settings, WPSR_Options::default_values( $id ) );
                $is_feature_active = ( isset( $feat_settings[ 'ft_status' ] ) && $feat_settings[ 'ft_status' ] == 'enable' ) ? true : false;
                $action_text = $is_feature_active ? esc_html__( 'Active', 'wp-socializer' ) : esc_html__( 'Inactive', 'wp-socializer' );
            }

            if( $config[ 'type' ] == 'widget' ){
                $action_text = __( 'Add widget', 'wp-socializer' );
            }

            $card_class = array(
                'page_card',
                'card_' . $id,
                ( $is_feature_active ? 'active' : '' )
            );

            echo '<a class="' . esc_attr( implode( ' ', $card_class ) ) . '" href="' . esc_attr( $link ) . '">';
            echo '<div class="card_info">';
            echo '<h3>' . esc_html( $config[ 'name' ] ) . '</h3>';
            if( !empty( $config[ 'description' ] ) ) echo '<p>' . esc_html( $config[ 'description' ] ) . '</p>';
            echo '</div>';
            echo '<div class="page_feat_status">' . esc_html( $action_text ) . '</div>';
            echo '</a>';
            
        }
        echo '</div>';
        
    }
    
    public static function settings_form( $id = '' ){

        if( empty( $id ) )
            return;

        $pages = self::get_pages();
        $page = $pages[ $id ];

        $form_name = $page[ 'form_name' ];
        $form_callback = $page[ 'callbacks' ][ 'form' ];
        
        $option = 'wpsr_' . $form_name;
        $nonce = 'wpsr_nonce_' . $form_name . '_submit';
        $form_fields = 'wpsr_form_' . $form_name;
        $validation_filter = 'wpsr_form_validation_' . $form_name;
        
        // Form post
        if( $_POST && check_admin_referer( $nonce ) ){
            
            $post = self::clean_post();
            $post_sanitized = apply_filters( $validation_filter, $post ); // Sanitize the options

            update_option( $option, $post_sanitized );
            
            echo '<div class="notice notice-success inline is-dismissible save_notice">';
            echo '<p>' . esc_html__( 'Settings saved successfully ! ', 'wp-socializer' );
            echo '<a href="' . esc_url( get_site_url() ) . '" target="_blank">' . esc_html__( 'Visit site', 'wp-socializer' ) . ' <i class="fas fa-arrow-right"></i></a></p>';
            echo '<p class="pro_msg">' . self::pro_msg() . '</p>';
            echo '</div>';
        }
        
        // Get saved details
        $saved_settings = get_option( $option );

        echo '<form method="post" id="' . esc_attr( $form_name ) . '" class="main_form">';
            
            // Execute all hooked form fields from services
            if( is_callable( $form_callback ) ){
                call_user_func( $form_callback, $saved_settings );
            }
            
            do_action( 'wpsr_form_' . $form_name, $saved_settings );
            
            wp_nonce_field( $nonce );
        
        echo '<div class="main_form_footer postbox"><input type="submit" value="' . esc_html__( 'Save settings', 'wp-socializer' ) . '" class="button button-primary" /></div>';
        
        self::pro_promo_box();

        echo '</form>';
        
    }
    
    public static function enqueue_scripts( $hook ){
        
        if( self::$pagehook == $hook ){
            wp_enqueue_style( 'wpsr_css', WPSR_ADMIN_URL . 'css/style.css', array(), WPSR_VERSION );
            wp_enqueue_style( 'wp-color-picker' );
            wp_enqueue_style( 'wpsr_ipopup', WPSR_ADMIN_URL . 'css/ipopup.css', array(), WPSR_VERSION );
            wp_enqueue_style( 'wpsr_fa', WPSR_Lists::ext_res( 'font-awesome-adm' ), array(), WPSR_VERSION );
            
            wp_enqueue_script( 'jquery' );
            wp_enqueue_script( 'jquery-conditioner', WPSR_ADMIN_URL . 'js/jquery.conditioner.js', array( 'jquery' ) );
            wp_enqueue_script( 'wp-color-picker' );
            wp_enqueue_script( 'jquery-ui-sortable' );
            wp_enqueue_script( 'jquery-ui-draggable' );
            wp_enqueue_script( 'wpsr_ipopup', WPSR_ADMIN_URL . 'js/ipopup.js', array(), WPSR_VERSION );
            wp_enqueue_script( 'wpsr_js', WPSR_ADMIN_URL . 'js/script.js', array( 'jquery', 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-conditioner', 'wp-color-picker', 'wpsr_ipopup' ), WPSR_VERSION );
            
        }
        
    }
    
    public static function inline_scripts(){
        
        $screen = get_current_screen();
        
        if( self::$pagehook == $screen->id ){
            
            $loc_rules = WPSR_Location_Rules::rules_list();
            
            $js_texts = array(
                'sel_btn' => __( 'Please select a service to create button for !', 'wp-socializer' ),
                'del_btn' => __( 'Are you sure want to delete this button ?', 'wp-socializer' ),
                'close' => __( 'Close', 'wp-socializer' ),
                'fb_empty' => __( 'No buttons are added. Open the editor to add buttons.', 'wp-socializer' )
            );
            
            echo '<script>
            var wpsr = {
                ajaxurl: "' . get_admin_url() . 'admin-ajax.php",
                loc_rules: ' . wp_json_encode( $loc_rules ) . ',
                js_texts: ' . wp_json_encode( $js_texts ) . ',
                ext_res: ' . wp_json_encode( WPSR_Lists::ext_res() ) . ',
                nonce: "' . wp_create_nonce( 'wpsr_ajax_nonce' ) . '"
            };
            </script>';
            
            echo '<script>
            var wpsr_show = {
                changelog: "' . ( ( get_option( 'wpsr_last_changelog' ) != WPSR_VERSION ) ? WPSR_VERSION : 'false'  ) . '"
            }
            </script>';
        }
        
    }
    
    public static function on_activate(){
        
        $prev_version = get_option( 'wpsr_version' );

        if( WPSR_VERSION != $prev_version ){
            update_option( 'wpsr_version', WPSR_VERSION );
        }
        
        if( !get_option( 'wpsr_since' ) ){
            add_option( 'wpsr_since', time() );
        }

    }

    public static function admin_ajax(){
        
        check_ajax_referer( 'wpsr_ajax_nonce' );

        if( !current_user_can( 'manage_options' ) ){
            wp_die();
        }

        $get = self::clean_get();
        $do = $get[ 'do' ];
        
        if( $do == 'close_changelog' ){
            update_option( 'wpsr_last_changelog', WPSR_VERSION );
            echo 'done';
        }

        die( 0 );
        
    }
    
    public static function clean_post(){
        return wp_unslash( $_POST );
    }
    
    public static function clean_attr( $a ){
        
        foreach( $a as $k=>$v ){
            if( is_array( $v ) ){
                $a[ $k ] = self::clean_attr( $v );
            }else{
                
                if( in_array( $k, array( 'custom', 'tip', 'helper', 'before_text', 'after_text' ) ) ){
                    $a[ $k ] = wp_kses_post( $v );
                }else{
                    $a[ $k ] = esc_attr( $v );
                }
                
            }
        }
        
        return $a;
    }
    
    public static function clean_get(){
        return wp_kses_post_deep( $_GET );
    }
    
    public static function action_links( $links ){
        array_unshift( $links, '<a href="'. esc_url( admin_url( 'admin.php?page=wp_socializer') ) .'">Settings</a>' );
        array_unshift( $links, '<a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/?utm_source=admin&utm_medium=action_link&utm_campaign=wpsr-pro#pro" target="_blank"><span style="font-weight: bold">' . esc_html__( 'Upgrade', 'wp-socializer' ) . '</span></a>' );

        return $links;
    }
    
    public static function admin_links(){
        echo '<ul class="admin_links">';
            echo '<li><a href="https://wordpress.org/support/plugin/wp-socializer/reviews/?rate=5#new-post" class="button" target="_blank">⭐ Rate &amp; Review</a></li>';
            echo '<li><a href="https://twitter.com/intent/follow?screen_name=aakashweb" class="button" target="_blank" title="Follow us Twitter"><i class="fab fa-x-twitter"></i></a></li>';
            echo '<li><a href="https://www.facebook.com/aakashweb/" class="button" target="_blank" title="Follow us Facebook"><i class="fab fa-facebook-f"></i></a></li>';
        echo '</ul>';
    }
    
    public static function footer_text( $text ){

        $screen = get_current_screen();

        if( self::$pagehook == $screen->id ){
            return '<img src="' . esc_url( WPSR_ADMIN_URL ) . '/images/icons/aakash-web.png" alt="Aakash Web" /> Thank you for using WP Socializer. Created by <a href="https://www.aakashweb.com" target="_blank">Aakash Chakravarthy</a>. More <a href="https://www.aakashweb.com/wordpress-plugins/" target="_blank">WordPress plugins</a>';
        }

        return $text;

    }

    public static function admin_sidebar(){

        echo '<div id="sidebar">';

        echo '<div class="side_card">';
        echo '<h2><i class="fas fa-life-ring"></i> Help &amp; Support</h2>';
        echo '<p>Got any issue or not sure how to achieve what you are looking for with the plugin or have any idea or missing feature ? Let me know. Please post a topic in the forum for an answer.</p>';
        echo '<a class="cta_link" href="https://www.aakashweb.com/docs/wp-socializer/" target="_blank">Documentation & FAQ <i class="fas fa-arrow-right"></i></a>';
        echo '<a class="cta_link" href="https://www.aakashweb.com/forum/discuss/wordpress-plugins/wp-socializer/" target="_blank">Visit the support forum <i class="fas fa-arrow-right"></i></a>';
        echo '</div>';

        echo '<div class="side_card">';
        echo '<h2><i class="fas fa-info-circle"></i> WordPress news</h2>';
        echo '<p>Get updates on the WordPress plugins, tips and tricks to enhance your WordPress experience. No spam.</p>';

    echo '<form class="subscribe_form" action="https://www.aakashweb.com/apps/subscription/" method="post" target="_blank" novalidate>
        <input type="text" value="' . esc_attr( wp_get_current_user()->user_email ) . '" name="email" class="required subscribe_email_box" placeholder="Your email address">
        <div style="display:none" aria-hidden="true"><input id="6aacb" type="checkbox" name="l" checked="" value="6aacb87c-0434-4ac1-b53c-22d7790ec4ac"></div>
        <input type="submit" value="Subscribe" name="subscribe" class="button subscribe_btn">
    </form>';
        echo '</div>';

        echo '</div>';

    }

    public static function pro_promo_box(){

        echo '<h2>More Features in PRO &nbsp; <i class="fa fa-star" style="color: #ffb72e;"></i></h2>';
        echo '<div class="side_card pro_card">';
        echo '<ul>';
        echo '<li>Create <a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/#pro" target="_blank">custom icons</a></li>';
        echo '<li>Change <a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/#pro" target="_blank">tweet text</a>, share URL, title for posts</li>';
        echo '<li>Track clicks on share & follow icons with <a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/#pro" target="_blank">Google Analytics</a></li>';
        echo '<li>Share short links with <a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/#pro" target="_blank">Bit.ly</a></li>';
        echo '<li>No branding.</li>';
        echo '</ul>';
        echo '<a class="button button-primary upgrade_btn" href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/?utm_source=admin&utm_medium=sidebar&utm_campaign=wpsr-pro#pro" target="_blank">Upgrade &nbsp;<i class="fas fa-angle-right"></i></a>';
        echo '</div>';

    }

    public static function intro_popups(){

        echo '<div class="welcome_wrap intro_popup style_ele">
        <section></section>
        <footer><button class="button button-primary close_changelog_btn">' . esc_html__( 'Start using WP Socializer', 'wp-socializer' ) . '</button> <a href="https://twitter.com/intent/tweet?hashtags=wordpress,plugin,facebook,twitter,addtoany,addthis&ref_src=twsrc%5Etfw&related=aakashweb&text=Check%20out%20WP%20Socializer%20⚡%20a%20free%20all%20in%20one%20plugin%20to%20add%20social%20sharing%20buttons%2C%20profile%20links%2C%20sticky%20share%20bar%20and%20widgets%20to%20your%20WordPress%20site&tw_p=tweetbutton&url=https%3A%2F%2Fwww.aakashweb.com%2Fwordpress-plugins%2Fwp-socializer%2F&via=aakashweb" class="button" target="_blank">Share on Twitter</a></footer>
        </div>';

    }

    public static function pro_msg(){

        $features = array(
            'you can Create <strong>Custom Icons</strong>',
            'you can Change <strong>Tweet Text</strong>, Share URL, Title for posts',
            'you can Track clicks on Share & Follow Icons with <strong>Google Analytics</strong>',
            'you can Share Short Links with <strong>Bit.ly</strong>',
            'there is NO <strong>Plugin branding</strong> ?'
        );

        $rand_feature_id = array_rand( $features );
        $feature = $features[ $rand_feature_id ];

        return '<span class="pro_tag">PRO Feature</span> In WP Socializer PRO, ' . wp_kses( $feature, array( 'strong' => array() ) ) . ' <a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/?utm_source=admin&utm_medium=save_msg&utm_campaign=wpsr-pro" target="_blank">Get this feature <i class="fas fa-arrow-right"></i></a>';

    }

}

WPSR_Admin::init();

?>