403Webshell
Server IP : 103.119.228.120  /  Your IP : 3.12.34.209
Web Server : Apache
System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64
User : nobody ( 99)
PHP Version : 5.6.40
Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime
MySQL : ON |  cURL : ON |  WGET : ON |  Perl : ON |  Python : ON |  Sudo : ON |  Pkexec : ON
Directory :  /home/hendraso/public_html/old/wp-content/plugins/secure-wordpress/res/inc/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/hendraso/public_html/old/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php
<?php if(! defined('SWPA_PLUGIN_PREFIX')) return;
/**
 * Class SwpaPlugin
 * Static class
 */
class SwpaPlugin
{
    public static function createWpMenu()
    {
        if (current_user_can('administrator') && function_exists('add_menu_page'))
        {
            $reqCap = 'activate_plugins';
            add_menu_page('Secure WP', 'Secure WP', $reqCap, SWPA_PLUGIN_PREFIX, array(get_class(),'pageMain'), SwpaUtil::imageUrl('logo-small.png'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'Dashboard', __('Dashboard'), $reqCap, SWPA_PLUGIN_PREFIX, array(get_class(),'pageMain'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'Database', __('Database'), $reqCap, SWPA_PLUGIN_PREFIX.'database', array(get_class(),'pageDatabase'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'Scanner', __('Scanner'), $reqCap, SWPA_PLUGIN_PREFIX.'scanner', array(get_class(),'pageScanner'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'Live traffic', __('Live traffic'), $reqCap, SWPA_PLUGIN_PREFIX.'live_traffic', array(get_class(),'pageLiveTraffic'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'Blog', __('Blog'), $reqCap, SWPA_PLUGIN_PREFIX.'blog', array(get_class(),'pageBlog'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'Settings', __('Settings'), $reqCap, SWPA_PLUGIN_PREFIX.'settings', array(get_class(),'pageSettings'));
            add_submenu_page(SWPA_PLUGIN_PREFIX, 'About', __('About'), $reqCap, SWPA_PLUGIN_PREFIX.'about', array(get_class(),'pageAbout'));
        }
    }

    public static function pageMain() { SwpaUtil::includePage('dashboard.php'); }
    public static function pageDatabase() { SwpaUtil::includePage('database.php'); }
    public static function pageScanner() { SwpaUtil::includePage('scanner.php'); }
    public static function pageLiveTraffic() { SwpaUtil::includePage('live_traffic.php'); }
    public static function pageBlog() { SwpaUtil::includePage('blog.php'); }
    public static function pageSettings() { SwpaUtil::includePage('settings.php'); }
    public static function pageAbout() { SwpaUtil::includePage('about.php'); }

    public static function loadResources()
    {
        if(SwpaUtil::canLoad()){
            wp_enqueue_style('wsd-styles-base', SwpaUtil::cssUrl('styles.base.css'));
            wp_enqueue_style('wsd-styles-alerts', SwpaUtil::cssUrl('styles.alerts.css'));
            wp_enqueue_style('wsd-styles-general', SwpaUtil::cssUrl('styles.general.css'));
            wp_enqueue_style('wsd-styles-status', SwpaUtil::cssUrl('styles.status.css'));
            wp_enqueue_script('wsdplugin-js-util', SwpaUtil::jsUrl('wsd-util.js'), array('jquery'));
        }
    }


    /**
     * Common method to add an alert to database.
     * @static
     * @param string $actionName The name of the action of the alert
     * @param int $type Can only be one of the following: SWPA_PLUGIN_ALERT_TYPE_OVERWRITE | SWPA_PLUGIN_ALERT_TYPE_STACK. Defaults to SWPA_PLUGIN_ALERT_TYPE_OVERWRITE
     * @param int $severity Can only have one of the following values: 0 1 2 3. Defaults to 0.
     * @param string $title
     * @param string $description
     * @param string $solution
     * @return bool
     */
    public static function alert($actionName, $type = 0, $severity = 0, $title = '', $description = '', $solution = '') {
        global $wpdb;

        $table = self::getTableName();

        if($type == SWPA_PLUGIN_ALERT_TYPE_STACK)
        {
            //#! Check the max number of stacked alerts to keep and remove the exceeding ones
            $afsDate = $wpdb->get_var("SELECT alertFirstSeen FROM $table WHERE alertActionName = '$actionName' ORDER BY `alertDate`;");
            if(empty($afsDate)){ $afsDate = "CURRENT_TIMESTAMP()";}
            else { $afsDate = "'".$afsDate."'"; }
            $result = $wpdb->get_var("SELECT COUNT(alertId) FROM $table WHERE alertActionName = '$actionName';");
            if($result >= SWPA_PLUGIN_ALERT_STACK_MAX_KEEP){
                // remove older entries to make room for the new ones
                $query = "DELETE FROM $table ORDER BY alertDate ASC LIMIT ".($result - (SWPA_PLUGIN_ALERT_STACK_MAX_KEEP - 1));
                $wpdb->query($query);
            }

            //Add the new entry
            $query = $wpdb->prepare(
                    "INSERT INTO $table
                    (`alertType`,
                    `alertSeverity`,
                    `alertActionName`,
                    `alertTitle`,
                    `alertDescription`,
                    `alertSolution`,
                    `alertDate`,
                    `alertFirstSeen`)
                    VALUES
                    (%d,
                     %d,
                     '%s',
                     '%s',
                     '%s',
                     '%s',
                     CURRENT_TIMESTAMP(),
                     $afsDate
                    );"
                ,$type, $severity, $actionName, $title, $description, $solution);
        }
        elseif($type == SWPA_PLUGIN_ALERT_TYPE_OVERWRITE)
        {
            //#! Find the record by actionName and update fields
            $result = $wpdb->get_var("SELECT alertId FROM $table WHERE alertActionName = '".$actionName."'; ");
            //#! found. do update
            if($result > 0){
                $query = $wpdb->prepare("UPDATE $table
                    SET
                    `alertType` = %d,
                    `alertSeverity` = %d,
                    `alertActionName` = '%s',
                    `alertTitle` = '%s',
                    `alertDescription` = '%s',
                    `alertSolution` = '%s',
                    `alertDate` = CURRENT_TIMESTAMP()
                    WHERE alertId = %d;",
                $type, $severity, $actionName, $title, $description, $solution,$result);
            }
            //#! record not found. insert query
            else {
                $query = $wpdb->prepare("INSERT INTO $table
                (`alertType`,
                `alertSeverity`,
                `alertActionName`,
                `alertTitle`,
                `alertDescription`,
                `alertSolution`,
                `alertDate`,
                `alertFirstSeen`)
                VALUES
                (%d,
                 %d,
                 '%s',
                 '%s',
                 '%s',
                 '%s',
                 CURRENT_TIMESTAMP(),
                 CURRENT_TIMESTAMP()
                );",
                $type, $severity, $actionName, $title, $description, $solution);
            }
        }
        $result = $wpdb->query($query);
        if($result === false){
            //#! MySQL error
            return false;
        }
        return true;
    }

    public static function getTableName($tableName = SWPA_PLUGIN_ALERT_TABLE_NAME){
        global $wpdb;
        return $wpdb->prefix.$tableName;
    }

    /**
     * Get all alerts grouped by alertActionName
     * @return array
     */
    public static function getAlerts()
    {
        global $wpdb;
        $columns = "`alertId`,`alertType`,`alertSeverity`,`alertActionName`,`alertTitle`,`alertDescription`,`alertSolution`,`alertDate`,`alertFirstSeen`";
        return $wpdb->get_results("SELECT $columns FROM ".self::getTableName(SWPA_PLUGIN_ALERT_TABLE_NAME)." GROUP BY `alertActionName`;");
    }

    // filter alerts by input
    public static function getAlertsBy($alertSeverity)
    {
        global $wpdb;
        $columns = "`alertId`,`alertType`,`alertSeverity`,`alertActionName`,`alertTitle`,`alertDescription`,`alertSolution`,`alertDate`,`alertFirstSeen`";
        return $wpdb->get_results("SELECT $columns FROM ".self::getTableName(SWPA_PLUGIN_ALERT_TABLE_NAME)." WHERE `alertSeverity` = '$alertSeverity' GROUP BY `alertActionName`;");
    }

    public static function getChildAlerts($alertId, $alertType)
    {
        global $wpdb;
        $columns = "`alertId`,`alertType`,`alertSeverity`,`alertActionName`,`alertTitle`,`alertDescription`,`alertSolution`,`alertDate`,`alertFirstSeen`";
        return $wpdb->get_results("SELECT $columns FROM ".self::getTableName()." WHERE (alertId <> $alertId AND alertType = '$alertType') ORDER BY `alertDate` DESC");
    }

    /**
     * Retrieve the settings from database. This method will extract all methods found in the SwpaSecurity class and provide them as
     * settings in the settings page. It will also auto update itself in case new methods are added to the class or if
     * some of them were removed.
     * @return array
     */
    public static function getSettings()
    {
        $className = 'SwpaSecurity';
        if(! class_exists($className)){
            return array();
        }
        $settings = get_option(SWPA_PLUGIN_SETTINGS_OPTION_NAME);
        $class = new ReflectionClass($className);
        $methods = $class->getMethods();

        if(empty($settings))
        {
            $settings = array();
            foreach($methods as $method)
            {
                $mn = $method->name;
                if($className != $method->class){
                    continue;
                }
                $comment = $method->getDocComment();
                if(false !== ($pos = strpos($mn,SwpaSecurity::$methodPrefix))){
                    $settings[$mn] = array(
                        'name' => $mn,
                        'value' => 0, // 0 or 1 ; whether or not the option will show as selected by default in the plugin's settings page
                        'desc' => trim(str_replace(array('/**','*/'),'', $comment))
                    );
                }
            }
            add_option(SWPA_PLUGIN_SETTINGS_OPTION_NAME, $settings);
        }
        else
        {
            $n1 = (isset($settings['keepNumEntriesLiveTraffic']) ? $settings['keepNumEntriesLiveTraffic'] : 500);
            $n2 = (isset($settings['liveTrafficRefreshRateAjax']) ? $settings['liveTrafficRefreshRateAjax'] : 10);

            // Check to see whether or not new methods were added or subtracted
            $numSettings = count($settings);
            $numMethods = count($methods);
            if($numMethods <> $numSettings)
            {
                // add new methods
                $_temp = array();
                foreach($methods as $method){
                    if($className != $method->class){
                        continue;
                    }
                    $comment = $method->getDocComment();
                    if(false === ($pos = strpos($method->name,SwpaSecurity::$methodPrefix))){ continue; }
                    if(! isset($settings[$method->name])){
                        $settings[$method->name] = array(
                            'name' => $method->name,
                            'value' => 0,
                            'desc' => trim(str_replace(array('/**','*/'),'', $comment))
                        );
                    }
                    array_push($_temp, $method->name);
                }
                // remove missing methods
                foreach($settings as $k => &$entry){
                    if(! in_array($entry['name'], $_temp)){
                        unset($settings[$k]);
                    }
                }

                $settings['keepNumEntriesLiveTraffic'] = $n1;
                $settings['liveTrafficRefreshRateAjax'] = $n2;
                update_option(SWPA_PLUGIN_SETTINGS_OPTION_NAME, $settings);
            }
        }
        return $settings;
    }

    /**
     * Check to see whether or not the provided setting is enabled (as the settings are configurable the user might chose to turn some of them off)
     * @param string $name The name of the setting to look for in the settings array
     * @return bool
     */
    public static function isSettingEnabled($name)
    {
        $settings = self::getSettings();
        return (isset($settings[$name]) ? $settings[$name]['value'] : false);
    }

    public static function activate()
    {
        global $wpdb;
        $charset_collate = '';

        if ( ! empty($wpdb->charset) ){$charset_collate = "DEFAULT CHARACTER SET $wpdb->charset";}
        if ( ! empty($wpdb->collate) ){$charset_collate .= " COLLATE $wpdb->collate";}

        // MUST HAVE "CREATE" RIGHTS if a table is not found and needs to be created
        $rights = SwpaInfoServer::getDatabaseUserAccessRights();
        $hasCreateRight = in_array('CREATE', $rights['rightsHaving']);
        $table1 = self::getTableName(SWPA_PLUGIN_ALERT_TABLE_NAME);
        $table2 = self::getTableName(SWPA_PLUGIN_LIVE_TRAFFIC_TABLE_NAME);

        if(! SwpaUtil::tableExists($table1)){
            $query1 = "CREATE TABLE IF NOT EXISTS ".$table1." (
                          `alertId` INT UNSIGNED NOT NULL AUTO_INCREMENT ,
                          `alertType` TINYINT NOT NULL DEFAULT 0 ,
                          `alertSeverity` INT NOT NULL DEFAULT 0 ,
                          `alertActionName` VARCHAR (255) NOT NULL,
                          `alertTitle` VARCHAR(255) NOT NULL ,
                          `alertDescription` TEXT NOT NULL ,
                          `alertSolution` TEXT NOT NULL ,
                          `alertDate` DATETIME NOT NULL default '0000-00-00 00:00:00',
                          `alertFirstSeen` DATETIME NOT NULL default '0000-00-00 00:00:00',
                          PRIMARY KEY (`alertId`) ,
                          UNIQUE INDEX `alertId_UNIQUE` (`alertId` ASC) ) $charset_collate;";
            if(! $hasCreateRight){
                $notices= get_option('wsd_plugin_install_error', array());
                $notices[]= '<strong>'.SWPA_PLUGIN_NAME."</strong>: The database user needs the '<strong>CREATE</strong>' right in order to install this plugin.";
                update_option('wsd_plugin_install_error', $notices);
                return;
            }
            $result = @$wpdb->query($query1);
            if($result === false){
                //#! MySQL error
                $GLOBALS['SWPA_PLUGIN_INSTALL_ERROR'] = 'Error running query: '.$query1;
                $notices= get_option('wsd_plugin_install_error', array());
                $notices[]= '<strong>'.SWPA_PLUGIN_NAME."</strong>. Error running query: <strong><pre>$query1</pre></strong>.";
                update_option('wsd_plugin_install_error', $notices);
                return;
            }
        }

        if(! SwpaUtil::tableExists($table2)){
            $query2 = "CREATE TABLE IF NOT EXISTS ".$table2." (
                         `entryId` bigint(20) unsigned NOT NULL auto_increment,
                         `entryTime` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
                         `entryIp` text,
                         `entryReferrer` text,
                         `entryUA` text,
                         `entryRequestedUrl` text,
                         PRIMARY KEY (entryId)) $charset_collate;";
            if(! $hasCreateRight){
                $notices= get_option('wsd_plugin_install_error', array());
                $notices[]= '<strong>'.SWPA_PLUGIN_NAME."</strong>: The database user needs the '<strong>CREATE</strong>' right in order to install this plugin.";
                update_option('wsd_plugin_install_error', $notices);
                return;
            }
            $result = @$wpdb->query($query2);
            if($result === false){
                //#! MySQL error
                $GLOBALS['SWPA_PLUGIN_INSTALL_ERROR'] = 'Error running query: '.$query2;
                $notices= get_option('wsd_plugin_install_error', array());
                $notices[]= '<strong>'.SWPA_PLUGIN_NAME."</strong>. Error running query: <strong><pre>$query2</pre></strong>.";
                update_option('wsd_plugin_install_error', $notices);
                return;
            }
        }

        add_option('WSD-PLUGIN-CAN-RUN-TASKS', 1);
    }
    public static function deactivate() {
        if(self::wpssPluginInstalled()){
            return;
        }
        SwpaScheduler::unregisterCronTasks();
        delete_option(SWPA_PLUGIN_SETTINGS_OPTION_NAME);
        delete_option('wsd_plugin_install_error');
        delete_option('WSD-PLUGIN-CAN-RUN-TASKS');
    }
    public static function uninstall(){
        if(self::wpssPluginInstalled()){
            return;
        }
        delete_option('SWPA_PLUGIN_ENTRIES_LIVE_TRAFFIC');
        global $wpdb;
        $wpdb->query("DROP TABLE IF EXISTS ".SwpaPlugin::getTableName(SWPA_PLUGIN_ALERT_TABLE_NAME));
        $wpdb->query("DROP TABLE IF EXISTS ".SwpaPlugin::getTableName(SWPA_PLUGIN_LIVE_TRAFFIC_TABLE_NAME));
    }

    /**
     * Check to see whether or not the Wp Security Scan plugin is installed
     * @return bool
     */
    public static function wpssPluginInstalled()
    {
        $pluginPath = 'wp-security-scan/index.php';
        $pluginFilePath = trailingslashit(ABSPATH).'wp-content/plugins/'.$pluginPath;
        if(function_exists('is_plugin_active')){
            if(is_plugin_active($pluginPath)){
                return true;
            }
            else {
                // check plugins dir
                if(is_file($pluginFilePath)){
                    return true;
                }
            }
        }
        // check plugins dir
        if(is_file($pluginFilePath)){
            return true;
        }
        return false;
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit