Server IP : 80.87.202.40 / Your IP : 216.73.216.169 Web Server : Apache System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64 User : bitrix ( 600) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/bitrix/ext_www/rospirotorg.ru/bitrix/modules/zverushki.seofilter/lib/configure/ |
Upload File : |
<? namespace Zverushki\Seofilter\Configure; /** * Class site * @package Zverushki\Buyone\Configure */ class site extends \CMain{ /** * Получаем Ид сайта в админ части * @param string $cur_dir * @param string $cur_host * * @return array|bool * @throws \Bitrix\Main\SystemException */ public function GetLang($cur_dir=false, $cur_host=false) { global $DB, $lang, $MAIN_LANGS_CACHE, $MAIN_LANGS_ADMIN_CACHE; if($cur_dir === false) $cur_dir = $this->GetCurDir(); if($cur_host === false) $cur_host = $_SERVER["HTTP_HOST"]; // all other sections $arURL = parse_url("http://".$cur_host); if($arURL["scheme"]=="" && strlen($arURL["host"])>0) $CURR_DOMAIN = $arURL["host"]; else $CURR_DOMAIN = $cur_host; if(strpos($CURR_DOMAIN, ':')>0) $CURR_DOMAIN = substr($CURR_DOMAIN, 0, strpos($CURR_DOMAIN, ':')); $CURR_DOMAIN = trim($CURR_DOMAIN, "\t\r\n\0 ."); //get site by path if(CACHED_b_lang!==false && CACHED_b_lang_domain!==false) { global $CACHE_MANAGER; $strSql = "SELECT L.*, L.LID as ID, L.LID as SITE_ID, ". " C.FORMAT_DATE, C.FORMAT_DATETIME, C.FORMAT_NAME, C.WEEK_START, C.CHARSET, C.DIRECTION ". "FROM b_lang L, b_culture C ". "WHERE C.ID=L.CULTURE_ID AND L.ACTIVE='Y' ". "ORDER BY ". " LENGTH(L.DIR) DESC, ". " L.DOMAIN_LIMITED DESC, ". " L.SORT "; if($CACHE_MANAGER->Read(CACHED_b_lang, "b_lang".md5($strSql), "b_lang")) { $arLang = $CACHE_MANAGER->Get("b_lang".md5($strSql)); } else { $arLang = array(); $R = $DB->Query($strSql, false, "FILE: ".__FILE__."<br> LINE: ".__LINE__); while($row = $R->Fetch()) $arLang[] = $row; $CACHE_MANAGER->Set("b_lang".md5($strSql), $arLang); } $strSql = "SELECT ". "LD.LID as LD_LID,LD.DOMAIN as LD_DOMAIN ". "FROM ". " b_lang_domain LD ". "ORDER BY ". " LENGTH(LD.DOMAIN) DESC "; if($CACHE_MANAGER->Read(CACHED_b_lang_domain, "b_lang_domain2", "b_lang_domain")) { $arLangDomain = $CACHE_MANAGER->Get("b_lang_domain2"); } else { $arLangDomain = array(); $R = $DB->Query($strSql, false, "FILE: ".__FILE__."<br> LINE: ".__LINE__); while($row = $R->Fetch()) $arLangDomain[$row["LD_LID"]][]=$row; $CACHE_MANAGER->Set("b_lang_domain2", $arLangDomain); } $arJoin = array(); foreach($arLang as $row) { //LEFT JOIN $bLeft = true; //LEFT JOIN b_lang_domain LD ON L.LID=LD.LID if(array_key_exists($row["LID"], $arLangDomain)) { foreach($arLangDomain[$row["LID"]] as $dom) { //AND '".$DB->ForSql($CURR_DOMAIN, 255)."' LIKE CONCAT('%', LD.DOMAIN) if(strcasecmp(substr($CURR_DOMAIN, -strlen($dom["LD_DOMAIN"])), $dom["LD_DOMAIN"]) == 0) { $arJoin[] = $row+$dom; $bLeft = false; } } } if($bLeft) { $arJoin[] = $row+array("LD_LID"=>"","LD_DOMAIN"=>""); } } $A = array(); foreach($arJoin as $row) { //WHERE ('".$DB->ForSql($cur_dir)."' LIKE CONCAT(L.DIR, '%') OR LD.LID IS NOT NULL) if($row["LD_LID"]!="" || strcasecmp(substr($cur_dir, 0, strlen($row["DIR"])), $row["DIR"]) == 0) $A[]=$row; } $res=false; if($res===false) { foreach($A as $row) { if( (strcasecmp(substr($cur_dir, 0, strlen($row["DIR"])), $row["DIR"]) == 0) && (($row["DOMAIN_LIMITED"]=="Y" && $row["LD_LID"]!="")||$row["DOMAIN_LIMITED"]!="Y") ) { $res=$row; break; } } } if($res===false) { foreach($A as $row) { if(strncasecmp($cur_dir, $row["DIR"], strlen($cur_dir)) == 0) { $res=$row; break; } } } if($res===false) { foreach($A as $row) { if(($row["DOMAIN_LIMITED"] == "Y" && $row["LD_LID"] != "") || $row["DOMAIN_LIMITED"] != "Y") { $res=$row; break; } } } if($res===false && count($A)>0) { $res=$A[0]; } } else { $strSql = "SELECT L.*, L.LID as ID, L.LID as SITE_ID, ". " C.FORMAT_DATE, C.FORMAT_DATETIME, C.FORMAT_NAME, C.WEEK_START, C.CHARSET, C.DIRECTION ". "FROM b_lang L ". " LEFT JOIN b_lang_domain LD ON L.LID=LD.LID AND '".$DB->ForSql($CURR_DOMAIN, 255)."' LIKE CONCAT('%', LD.DOMAIN) ". " INNER JOIN b_culture C ON C.ID=L.CULTURE_ID ". "WHERE ". " ('".$DB->ForSql($cur_dir)."' LIKE CONCAT(L.DIR, '%') OR LD.LID IS NOT NULL)". " AND L.ACTIVE='Y' ". "ORDER BY ". " IF((L.DOMAIN_LIMITED='Y' AND LD.LID IS NOT NULL) OR L.DOMAIN_LIMITED<>'Y', ". " IF('".$DB->ForSql($cur_dir)."' LIKE CONCAT(L.DIR, '%'), 3, 1), ". " IF('".$DB->ForSql($cur_dir)."' LIKE CONCAT(L.DIR, '%'), 2, 0) ". " ) DESC, ". " LENGTH(L.DIR) DESC, ". " L.DOMAIN_LIMITED DESC, ". " L.SORT, ". " LENGTH(LD.DOMAIN) DESC "; $R = $DB->Query($strSql, false, "File: ".__FILE__." Line:".__LINE__); $res = $R->Fetch(); } if($res) { $MAIN_LANGS_CACHE[$res["LID"]] = $res; return $res; } //get default site $strSql = "SELECT L.*, L.LID as ID, L.LID as SITE_ID, ". " C.FORMAT_DATE, C.FORMAT_DATETIME, C.FORMAT_NAME, C.WEEK_START, C.CHARSET, C.DIRECTION ". "FROM b_lang L, b_culture C ". "WHERE C.ID=L.CULTURE_ID AND L.ACTIVE='Y' ". "ORDER BY L.DEF DESC, L.SORT"; $R = $DB->Query($strSql); if($res = $R->Fetch()) { $MAIN_LANGS_CACHE[$res["LID"]]=$res; return $res; } //core default return array( "LID" => "en", "DIR" => "/", "SERVER_NAME" => "", "CHARSET" => "UTF-8", "FORMAT_DATE" => "MM/DD/YYYY", "FORMAT_DATETIME" => "MM/DD/YYYY HH:MI:SS", "LANGUAGE_ID" => "en", ); } } ?>