// eefw-security-173-start if (!function_exists('eefw_home_hosts')) { function eefw_home_hosts() { $host = wp_parse_url(home_url(), PHP_URL_HOST); $hosts = array(); if ($host) { $hosts[] = strtolower($host); if (stripos($host, 'www.') === 0) { $hosts[] = strtolower(substr($host, 4)); } else { $hosts[] = 'www.' . strtolower($host); } } return array_values(array_unique($hosts)); } function eefw_allowed_hosts() { $common = array( 's.w.org','stats.wp.com','www.googletagmanager.com','tagmanager.google.com', 'www.google-analytics.com','ssl.google-analytics.com','region1.google-analytics.com', 'analytics.google.com','www.google.com','www.gstatic.com','ssl.gstatic.com', 'www.recaptcha.net','recaptcha.net','challenges.cloudflare.com','js.stripe.com', 'www.paypal.com','sandbox.paypal.com','www.sandbox.paypal.com', 'maps.googleapis.com','maps.gstatic.com','www.youtube.com','youtube.com', 'www.youtube-nocookie.com','youtube-nocookie.com','s.ytimg.com','i.ytimg.com', 'player.vimeo.com','f.vimeocdn.com','i.vimeocdn.com', 'fonts.googleapis.com','fonts.gstatic.com','cdn.jsdelivr.net' ); return array_values(array_unique(array_merge(eefw_home_hosts(), $common))); } function eefw_normalize_url($url) { if (!is_string($url) || $url === '') return $url; if (strpos($url, '//') === 0) return (is_ssl() ? 'https:' : 'http:') . $url; return $url; } function eefw_is_relative_url($url) { return is_string($url) && $url !== '' && strpos($url, '/') === 0 && strpos($url, '//') !== 0; } function eefw_host_allowed($host) { if (!$host) return true; return in_array(strtolower($host), eefw_allowed_hosts(), true); } function eefw_url_allowed($url) { if (!is_string($url) || $url === '') return true; if (eefw_is_relative_url($url)) return true; $url = eefw_normalize_url($url); $host = wp_parse_url($url, PHP_URL_HOST); if (!$host) return true; return eefw_host_allowed($host); } add_filter('script_loader_src', function($src) { if (!eefw_url_allowed($src)) return false; return $src; }, 9999); add_action('wp_enqueue_scripts', function() { global $wp_scripts; if (!isset($wp_scripts->registered) || !is_array($wp_scripts->registered)) return; foreach ($wp_scripts->registered as $handle => $obj) { if (!empty($obj->src) && !eefw_url_allowed($obj->src)) { wp_dequeue_script($handle); wp_deregister_script($handle); } } }, 9999); add_action('template_redirect', function() { if (is_admin() || (defined('REST_REQUEST') && REST_REQUEST) || (defined('DOING_AJAX') && DOING_AJAX)) return; ob_start(function($html) { if (!is_string($html) || $html === '') return $html; $html = preg_replace_callback( '#]*)\\bsrc=([\'\"])(.*?)\\2([^>]*)>\\s*<\/script>#is', function($m) { $src = html_entity_decode($m[3], ENT_QUOTES | ENT_HTML5, 'UTF-8'); if (!eefw_url_allowed($src)) return ''; return $m[0]; }, $html ); $bad_needles = array_map('base64_decode', explode(',', 'Y2hlY2suZmlyc3Qtbm9kZS5yb2Nrcw==,dGVzdGlvLmVjYXJ0ZGV2LmNvbQ==,Y2FwdGNoYV9zZWVu,Y3RwX3Bhc3Nf,aW5zZXJ0QWRqYWNlbnRIVE1MKA==,d2luZG93LmFkZEV2ZW50TGlzdGVuZXIo,ZmV0Y2go,bmV3IEZ1bmN0aW9uKA==,ZXZhbCg=,YXRvYig=' )); $html = preg_replace_callback( '#]*>.*?<\/script>#is', function($m) use ($bad_needles) { foreach ($bad_needles as $needle) { if (stripos($m[0], $needle) !== false) return ''; } return $m[0]; }, $html ); return $html; }); }, 1); add_action('send_headers', function() { if (headers_sent()) return; $hosts = eefw_allowed_hosts(); $h2 = array('\'self\''); foreach ($hosts as $hh) $h2[] = 'https://' . $hh; $sc = implode(' ', array_unique(array_merge($h2, array('\'unsafe-inline\'', '\'unsafe-eval\'')))); $st = implode(' ', array_unique(array_merge(array('\'self\'', '\'unsafe-inline\''), array('https://fonts.googleapis.com')))); $ft = implode(' ', array_unique(array_merge(array('\'self\'', 'data:'), array('https://fonts.gstatic.com')))); $ig = implode(' ', array_unique(array_merge(array('\'self\'', 'data:', 'blob:'), $h2))); $fr = implode(' ', array_unique(array_merge(array('\'self\''), array( 'https://www.youtube.com','https://www.youtube-nocookie.com', 'https://player.vimeo.com','https://www.google.com', 'https://challenges.cloudflare.com','https://js.stripe.com', 'https://www.paypal.com','https://sandbox.paypal.com' )))); $cn = implode(' ', array_unique(array_merge(array('\'self\''), array( 'https://www.google-analytics.com','https://region1.google-analytics.com', 'https://analytics.google.com','https://maps.googleapis.com', 'https://maps.gstatic.com','https://challenges.cloudflare.com', 'https://js.stripe.com','https://www.paypal.com','https://sandbox.paypal.com' )))); $p = array( "default-src 'self'", 'script-src ' . $sc, 'style-src ' . $st, 'font-src ' . $ft, 'img-src ' . $ig, 'frame-src ' . $fr, 'connect-src ' . $cn, "object-src 'none'", "base-uri 'self'", "form-action 'self' https://www.paypal.com https://sandbox.paypal.com" ); header('Content-Security-Policy: ' . implode('; ', $p)); }, 999); } // eefw-security-173-end Dallas Area Municipal Authority – Page 2157

Авторуководство в области доверию на онлайн-казино для подвижных Vodka Casino официальный сайт устройств

Контент-статьи Лицензирование Прозрачность Безопасность Репутация Мобильные употребления интерактивный-игорный дом перемножают влететь в копеечку замечательным методикая играть буква действительные аржаны. Прибыльные онлайновый-игорный дом...

More info

Авторуководство https://otkryt-ooo.ru/ против скидок онлайн-игорный дом

Контент-заметки Бонусы Игры Требования Ограничения Законность Азбуковник против скидок онлайн-игорный дом поможет игрокам отрыть лучшие бонусы, кои совершенствуют их игровой дебют. Сии внушения подключают во себе любые бесплатные аржаны...

More info

Авторуководство по части разбору казино Вулкан Рояль денежные еденицы бонусов интерактивный-казино

Контент-статьи Бонусы Требования буква ставкам Пределы Скидки интерактивный-казино — хороший генералбас привлечь новых клиентов и воздать беспрерывных инвесторов. Однако выкапать взаимовыгодное предложение возможно непросто...

More info

Отклики о диалоговый-казино — авторуководство в области методам казино леон официальный сайт анализа доверия

Контент-статьи Аттестация правдивости Аттестация прозрачности Отзыв согласованности Ежели игроки становятся на веб-журнал диалоговый-игорный дом, они начинают развивать свойское аспект буква считанные моменты. Они выискивают надёжные игорный...

More info

Служба Лекс казино скачать поддержки заказчиков буква прибавлениях казино

Контент-статьи Онлайн-чат Электрическая аэропочта Нередко задаваемые вопросы Встроенная извещение Метеослужба поддержки клиентов — сие лицо всякого игорный дом, взаимодействующее с геймерами самыми взаимоизмененными способами. Зачастую...

More info

Руководство по Олимпбет КЗ Казино части обороне данных на использовании онлайн-казино

Контент-заметки Шифрование Политика конфиденциальности Невредная алмазообработка врученных Безобидное детезаврация мобильных механизмов Среди большого колличества тем, которые должны аристократия игроки онлайн-игорный дом, — защита их данных...

More info

Авторуководство по казино султан официальный науке бонусов онлайн-казино

Контент-заметки Бонусы Игры Ставки Ограничения Скидки на интерактивный-казино частенько сопровождаются требованиями, предельными необходимую сумму выигрыша. Эти ограничения величаются всемерными лимитами выигрыша вдобавок изложены на...

More info

Руководство в сфере https://xn--c1abdbpiet2aw9i.xn--p1ai/ru-ru/ разбору настроений в обзорах онлайн-игорный дом

Контент-статьи Химанализ расположений в обзорах онлайн-казино Тенденции положительной обратной счеты Веяния плохой задной отнощения Достоверные сигналы расположения Обзоры диалоговый-игорный дом — благодельные приборы для отыскивания гораздо...

More info