work
Dieser Commit ist enthalten in:
Ursprung
dcc1f7f323
Commit
dc11334aaf
1 geänderte Dateien mit 165 neuen und 192 gelöschten Zeilen
|
@ -1,4 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Project:
|
* Project:
|
||||||
* Contenido Content Management System
|
* Contenido Content Management System
|
||||||
|
@ -31,215 +32,191 @@
|
||||||
* }}
|
* }}
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
if (!defined('CON_FRAMEWORK')) {
|
||||||
if(!defined('CON_FRAMEWORK')) {
|
die('Illegal call');
|
||||||
die('Illegal call');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Checks all links without front_content.php
|
// Checks all links without front_content.php
|
||||||
function checkLinks() {
|
function checkLinks() {
|
||||||
global $auth, $cfgClient, $client, $cfg, $cronjob, $db, $aErrors, $lang, $langart, $whitelist;
|
global $auth, $cfgClient, $client, $cfg, $cronjob, $db, $aErrors, $lang, $langart, $whitelist;
|
||||||
global $aSearchIDInfosArt, $aSearchIDInfosCat, $aSearchIDInfosCatArt, $aSearchIDInfosNonID;
|
global $aSearchIDInfosArt, $aSearchIDInfosCat, $aSearchIDInfosCatArt, $aSearchIDInfosNonID;
|
||||||
|
|
||||||
if(count($aSearchIDInfosArt) > 0) { // Checks idarts
|
if (count($aSearchIDInfosArt) > 0) { // Checks idarts
|
||||||
|
for ($i = 0; $i < count($aSearchIDInfosArt); $i++) {
|
||||||
|
|
||||||
for($i = 0; $i < count($aSearchIDInfosArt); $i++) {
|
if ($i == 0) {
|
||||||
|
$sSearch = Contenido_Security::toInteger($aSearchIDInfosArt[$i]['id']);
|
||||||
if($i == 0) {
|
} else {
|
||||||
$sSearch = Contenido_Security::toInteger($aSearchIDInfosArt[$i]['id']);
|
$sSearch .= ", " . Contenido_Security::toInteger($aSearchIDInfosArt[$i]['id']);
|
||||||
} else {
|
}
|
||||||
$sSearch .= ", " . Contenido_Security::toInteger($aSearchIDInfosArt[$i]['id']);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check articles
|
|
||||||
$aFind = array();
|
|
||||||
$sql = "SELECT idart, online FROM " . $cfg['tab']['art_lang'] . " WHERE idart IN (" . $sSearch . ")";
|
|
||||||
$db->query($sql);
|
|
||||||
|
|
||||||
while($db->next_record()) {
|
|
||||||
$aFind[$db->f("idart")] = array("online" => $db->f("online"));
|
|
||||||
}
|
|
||||||
|
|
||||||
for($i = 0; $i < count($aSearchIDInfosArt); $i++) {
|
|
||||||
|
|
||||||
if(isset($aFind[$aSearchIDInfosArt[$i]['id']]) && $aFind[$aSearchIDInfosArt[$i]['id']]['online'] == 0) {
|
|
||||||
$aErrors['art'][] = array_merge($aSearchIDInfosArt[$i], array("error_type" => "offline"));
|
|
||||||
} elseif(!isset($aFind[$aSearchIDInfosArt[$i]['id']])) {
|
|
||||||
$aErrors['art'][] = array_merge($aSearchIDInfosArt[$i], array("error_type" => "unknown"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
$int_cnt_aSearchIDInfosCat = 0;
|
|
||||||
|
|
||||||
if(is_countable($aSearchIDInfosCat)) {
|
|
||||||
$int_cnt_aSearchIDInfosCat = count($aSearchIDInfosCat);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if($int_cnt_aSearchIDInfosCat > 0) { // Checks idcats
|
// Check articles
|
||||||
|
$aFind = array();
|
||||||
|
$sql = "SELECT idart, online FROM " . $cfg['tab']['art_lang'] . " WHERE idart IN (" . $sSearch . ")";
|
||||||
|
$db->query($sql);
|
||||||
|
|
||||||
for($i = 0; $i < $int_cnt_aSearchIDInfosCat; $i++) {
|
while ($db->next_record()) {
|
||||||
|
$aFind[$db->f("idart")] = array("online" => $db->f("online"));
|
||||||
|
}
|
||||||
|
|
||||||
if($i == 0) {
|
for ($i = 0; $i < count($aSearchIDInfosArt); $i++) {
|
||||||
$sSearch = $aSearchIDInfosCat[$i]['id'];
|
|
||||||
} else {
|
|
||||||
$sSearch .= ", " . $aSearchIDInfosCat[$i]['id'];
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
if (isset($aFind[$aSearchIDInfosArt[$i]['id']]) && $aFind[$aSearchIDInfosArt[$i]['id']]['online'] == 0) {
|
||||||
|
$aErrors['art'][] = array_merge($aSearchIDInfosArt[$i], array("error_type" => "offline"));
|
||||||
|
} elseif (!isset($aFind[$aSearchIDInfosArt[$i]['id']])) {
|
||||||
|
$aErrors['art'][] = array_merge($aSearchIDInfosArt[$i], array("error_type" => "unknown"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Check categorys
|
$int_cnt_aSearchIDInfosCat = 0;
|
||||||
$aFind = array();
|
|
||||||
$sql = "SELECT idcat, startidartlang, visible FROM " . $cfg['tab']['cat_lang'] . " WHERE idcat IN (" . $sSearch . ") AND idlang = '" . Contenido_Security::toInteger($lang) . "'";
|
|
||||||
$db->query($sql);
|
|
||||||
|
|
||||||
while($db->next_record()) {
|
if (is_countable($aSearchIDInfosCat)) {
|
||||||
$aFind[$db->f("idcat")] = array("online" => $db->f("visible"), "startidart" => $db->f("startidartlang"));
|
$int_cnt_aSearchIDInfosCat = count($aSearchIDInfosCat);
|
||||||
}
|
}
|
||||||
|
|
||||||
for($i = 0; $i < count($aSearchIDInfosCat); $i++) {
|
if ($int_cnt_aSearchIDInfosCat > 0) { // Checks idcats
|
||||||
|
for ($i = 0; $i < $int_cnt_aSearchIDInfosCat; $i++) {
|
||||||
|
|
||||||
if(is_array($aFind[$aSearchIDInfosCat[$i]['id']]) && $aFind[$aSearchIDInfosCat[$i]['id']]['startidart'] == 0) {
|
if ($i == 0) {
|
||||||
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "startart"));
|
$sSearch = $aSearchIDInfosCat[$i]['id'];
|
||||||
} elseif(is_array($aFind[$aSearchIDInfosCat[$i]['id']]) && $aFind[$aSearchIDInfosCat[$i]['id']]['online'] == 0) {
|
} else {
|
||||||
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "offline"));
|
$sSearch .= ", " . $aSearchIDInfosCat[$i]['id'];
|
||||||
} elseif(!is_array($aFind[$aSearchIDInfosCat[$i]['id']])) {
|
}
|
||||||
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "unknown"));
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if(is_array($aFind[$aSearchIDInfosCat[$i]['id']]) && $aFind[$aSearchIDInfosCat[$i]['id']]['startidart'] != 0) {
|
// Check categorys
|
||||||
|
$aFind = array();
|
||||||
|
$sql = "SELECT idcat, startidartlang, visible FROM " . $cfg['tab']['cat_lang'] . " WHERE idcat IN (" . $sSearch . ") AND idlang = '" . Contenido_Security::toInteger($lang) . "'";
|
||||||
|
$db->query($sql);
|
||||||
|
|
||||||
$sql = "SELECT idart FROM " . $cfg['tab']['art_lang'] . " WHERE idartlang = '" . $aFind[$aSearchIDInfosCat[$i]['id']]['startidart'] . "' AND online = '1'";
|
while ($db->next_record()) {
|
||||||
$db->query($sql);
|
$aFind[$db->f("idcat")] = array("online" => $db->f("visible"), "startidart" => $db->f("startidartlang"));
|
||||||
|
}
|
||||||
|
|
||||||
if($db->num_rows() == 0) {
|
for ($i = 0; $i < count($aSearchIDInfosCat); $i++) {
|
||||||
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "startart"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
if (is_array($aFind[$aSearchIDInfosCat[$i]['id']]) && $aFind[$aSearchIDInfosCat[$i]['id']]['startidart'] == 0) {
|
||||||
|
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "startart"));
|
||||||
|
} elseif (is_array($aFind[$aSearchIDInfosCat[$i]['id']]) && $aFind[$aSearchIDInfosCat[$i]['id']]['online'] == 0) {
|
||||||
|
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "offline"));
|
||||||
|
} elseif (!is_array($aFind[$aSearchIDInfosCat[$i]['id']])) {
|
||||||
|
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "unknown"));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
if (is_array($aFind[$aSearchIDInfosCat[$i]['id']]) && $aFind[$aSearchIDInfosCat[$i]['id']]['startidart'] != 0) {
|
||||||
|
|
||||||
}
|
$sql = "SELECT idart FROM " . $cfg['tab']['art_lang'] . " WHERE idartlang = '" . $aFind[$aSearchIDInfosCat[$i]['id']]['startidart'] . "' AND online = '1'";
|
||||||
|
$db->query($sql);
|
||||||
|
|
||||||
if(count($aSearchIDInfosCatArt) > 0) { // Checks idcatarts
|
if ($db->num_rows() == 0) {
|
||||||
|
$aErrors['cat'][] = array_merge($aSearchIDInfosCat[$i], array("error_type" => "startart"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for($i = 0; $i < count($aSearchIDInfosCatArt); $i++) {
|
if (count($aSearchIDInfosCatArt) > 0) { // Checks idcatarts
|
||||||
|
for ($i = 0; $i < count($aSearchIDInfosCatArt); $i++) {
|
||||||
|
|
||||||
if($i == 0) {
|
if ($i == 0) {
|
||||||
$sSearch = Contenido_Security::toInteger($aSearchIDInfosCatArt[$i]['id']);
|
$sSearch = Contenido_Security::toInteger($aSearchIDInfosCatArt[$i]['id']);
|
||||||
} else {
|
} else {
|
||||||
$sSearch .= ", " . Contenido_Security::toInteger($aSearchIDInfosCatArt[$i]['id']);
|
$sSearch .= ", " . Contenido_Security::toInteger($aSearchIDInfosCatArt[$i]['id']);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
// Check articles
|
||||||
|
$aFind = array();
|
||||||
|
$sql = "SELECT idcatart FROM " . $cfg['tab']['cat_art'] . " WHERE idcatart IN (" . $sSearch . ")";
|
||||||
|
$db->query($sql);
|
||||||
|
|
||||||
// Check articles
|
while ($db->next_record()) {
|
||||||
$aFind = array();
|
$aFind[] = $db->f("idcatart");
|
||||||
$sql = "SELECT idcatart FROM " . $cfg['tab']['cat_art'] . " WHERE idcatart IN (" . $sSearch . ")";
|
}
|
||||||
$db->query($sql);
|
|
||||||
|
|
||||||
while($db->next_record()) {
|
for ($i = 0; $i < count($aSearchIDInfosCatArt); $i++) {
|
||||||
$aFind[] = $db->f("idcatart");
|
|
||||||
}
|
|
||||||
|
|
||||||
for($i = 0; $i < count($aSearchIDInfosCatArt); $i++) {
|
if (!in_array($aSearchIDInfosCatArt[$i]['id'], $aFind)) {
|
||||||
|
$aErrors['art'][] = array_merge($aSearchIDInfosCatArt[$i], array("error_type" => "unknown"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(!in_array($aSearchIDInfosCatArt[$i]['id'], $aFind)) {
|
if (count($aSearchIDInfosNonID) != 0) { // Checks other links (e. g. http, www, dfbs)
|
||||||
$aErrors['art'][] = array_merge($aSearchIDInfosCatArt[$i], array("error_type" => "unknown"));
|
// Select userrights (is the user admin or sysadmin?)
|
||||||
}
|
$sql = "SELECT username FROM " . $cfg['tab']['phplib_auth_user_md5'] . " WHERE user_id='" . Contenido_Security::escapeDB($auth->auth['uid'], $db) . "' AND perms LIKE '%admin%'";
|
||||||
|
$db->query($sql);
|
||||||
|
|
||||||
}
|
if ($db->num_rows() > 0 || $cronjob == true) { // User is admin when he is or when he run the cronjob
|
||||||
|
$iAdmin = true;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
for ($i = 0; $i < count($aSearchIDInfosNonID); $i++) {
|
||||||
|
|
||||||
if(count($aSearchIDInfosNonID) != 0) { // Checks other links (e. g. http, www, dfbs)
|
if (url_is_uri($aSearchIDInfosNonID[$i]['url'])) {
|
||||||
|
|
||||||
// Select userrights (is the user admin or sysadmin?)
|
if (substr($aSearchIDInfosNonID[$i]['url'], 0, strlen($aSearchIDInfosNonID[$i]['url'])) == $cfgClient[$client]['path']['htmlpath']) {
|
||||||
$sql = "SELECT username FROM " . $cfg['tab']['phplib_auth_user_md5'] . " WHERE user_id='" . Contenido_Security::escapeDB($auth->auth['uid'], $db) . "' AND perms LIKE '%admin%'";
|
$iPing = @file_exists(str_replace($cfgClient[$client]['path']['htmlpath'], $cfgClient[$client]['path']['frontend'], $aSearchIDInfosNonID[$i]['url']));
|
||||||
$db->query($sql);
|
} else {
|
||||||
|
$iPing = @fopen($aSearchIDInfosNonID[$i]['url'], 'r');
|
||||||
|
}
|
||||||
|
|
||||||
if($db->num_rows() > 0 || $cronjob == true) { // User is admin when he is or when he run the cronjob
|
if (!$iPing) {
|
||||||
$iAdmin = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
for($i = 0; $i < count($aSearchIDInfosNonID); $i++) {
|
if (url_is_image($aSearchIDInfosNonID[$i]['url'])) {
|
||||||
|
$aErrors['docimages'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
||||||
|
} else {
|
||||||
|
$aErrors['others'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} elseif (substr($aSearchIDInfosNonID[$i]['url'], strlen($aSearchIDInfosNonID[$i]['url']) - 5, 5) == ".html") {
|
||||||
|
|
||||||
if(url_is_uri($aSearchIDInfosNonID[$i]['url'])) {
|
$iPing = @file_exists($cfgClient[$client]['path']['htmlpath'] . $aSearchIDInfosNonID[$i]['url']);
|
||||||
|
|
||||||
if(substr($aSearchIDInfosNonID[$i]['url'], 0, strlen($aSearchIDInfosNonID[$i]['url'])) == $cfgClient[$client]['path']['htmlpath']) {
|
if (!$iPing) {
|
||||||
$iPing = @file_exists(str_replace($cfgClient[$client]['path']['htmlpath'], $cfgClient[$client]['path']['frontend'], $aSearchIDInfosNonID[$i]['url']));
|
$aErrors['art'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
||||||
} else {
|
}
|
||||||
$iPing = @fopen($aSearchIDInfosNonID[$i]['url'], 'r');
|
} elseif (substr($aSearchIDInfosNonID[$i]['url'], 0, 20) == "dbfs.php?file=dbfs:/") {
|
||||||
}
|
|
||||||
|
|
||||||
if(!$iPing) {
|
$sDBurl = substr($aSearchIDInfosNonID[$i]['url'], 20, strlen($aSearchIDInfosNonID[$i]['url']));
|
||||||
|
|
||||||
if(url_is_image($aSearchIDInfosNonID[$i]['url'])) {
|
$iPos = strrpos($sDBurl, '/');
|
||||||
$aErrors['docimages'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
$sDirname = substr($sDBurl, 0, $iPos);
|
||||||
} else {
|
$sFilename = substr($sDBurl, $iPos + 1);
|
||||||
$aErrors['others'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
// Check categorys
|
||||||
|
$sql = "SELECT iddbfs FROM " . $cfg['tab']['dbfs'] . " WHERE dirname IN('" . $sDirname . "', '" . clHtmlEntityDecode($sDirname) . "', '" . urldecode($sDirname) . "') AND filename = '" . $sFilename . "'";
|
||||||
|
$db->query($sql);
|
||||||
|
|
||||||
} elseif(substr($aSearchIDInfosNonID[$i]['url'], strlen($aSearchIDInfosNonID[$i]['url'])-5, 5) == ".html") {
|
if ($db->num_rows() == 0) {
|
||||||
|
$aErrors['docimages'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "dbfs"));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
|
||||||
$iPing = @file_exists($cfgClient[$client]['path']['htmlpath'] . $aSearchIDInfosNonID[$i]['url']);
|
if (!file_exists($cfgClient[$client]['path']['frontend'] . $aSearchIDInfosNonID[$i]['url'])) {
|
||||||
|
|
||||||
if(!$iPing) {
|
if (url_is_image($aSearchIDInfosNonID[$i]['url'])) {
|
||||||
$aErrors['art'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
$aErrors['docimages'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
||||||
}
|
} else {
|
||||||
|
$aErrors['others'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
||||||
} elseif(substr($aSearchIDInfosNonID[$i]['url'], 0, 20) == "dbfs.php?file=dbfs:/") {
|
}
|
||||||
|
}
|
||||||
$sDBurl = substr($aSearchIDInfosNonID[$i]['url'], 20, strlen($aSearchIDInfosNonID[$i]['url']));
|
}
|
||||||
|
}
|
||||||
$iPos = strrpos($sDBurl, '/');
|
}
|
||||||
$sDirname = substr($sDBurl, 0, $iPos);
|
|
||||||
$sFilename = substr($sDBurl, $iPos + 1);
|
|
||||||
|
|
||||||
// Check categorys
|
|
||||||
$sql = "SELECT iddbfs FROM " . $cfg['tab']['dbfs'] . " WHERE dirname IN('" . $sDirname . "', '" . clHtmlEntityDecode($sDirname) . "', '" . urldecode($sDirname) . "') AND filename = '" . $sFilename . "'";
|
|
||||||
$db->query($sql);
|
|
||||||
|
|
||||||
if($db->num_rows() == 0) {
|
|
||||||
$aErrors['docimages'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "dbfs"));
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
|
||||||
|
|
||||||
if(!file_exists($cfgClient[$client]['path']['frontend'] . $aSearchIDInfosNonID[$i]['url'])) {
|
|
||||||
|
|
||||||
if(url_is_image($aSearchIDInfosNonID[$i]['url'])) {
|
|
||||||
$aErrors['docimages'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
|
||||||
} else {
|
|
||||||
$aErrors['others'][] = array_merge($aSearchIDInfosNonID[$i], array("error_type" => "unknown"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return $aErrors;
|
|
||||||
|
|
||||||
|
return $aErrors;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Searchs front_content.php-links
|
// Searchs front_content.php-links
|
||||||
function searchFrontContentLinks($sValue, $iArt, $sArt, $iCat, $sCat) {
|
function searchFrontContentLinks($sValue, $iArt, $sArt, $iCat, $sCat) {
|
||||||
global $aSearchIDInfosArt, $aSearchIDInfosCat, $aSearchIDInfosCatArt, $aWhitelist;
|
global $aSearchIDInfosArt, $aSearchIDInfosCat, $aSearchIDInfosCatArt, $aWhitelist;
|
||||||
|
|
||||||
// detect urls with parameter idart
|
// detect urls with parameter idart
|
||||||
$matches = array();
|
$matches = array();
|
||||||
if (preg_match_all('/(?!file|ftp|http|ww)front_content.php\?idart=([0-9]*)/i', $sValue, $matches)) {
|
if (preg_match_all('/(?!file|ftp|http|ww)front_content.php\?idart=([0-9]*)/i', $sValue, $matches)) {
|
||||||
for ($i = 0; $i < count($matches[0]); $i++) {
|
for ($i = 0; $i < count($matches[0]); $i++) {
|
||||||
if (!in_array($matches[0][$i], $aWhitelist)) {
|
if (!in_array($matches[0][$i], $aWhitelist)) {
|
||||||
$aSearchIDInfosArt[] = array(
|
$aSearchIDInfosArt[] = array(
|
||||||
|
@ -247,11 +224,11 @@ function searchFrontContentLinks($sValue, $iArt, $sArt, $iCat, $sCat) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// detect urls with parameter idcat
|
// detect urls with parameter idcat
|
||||||
$matches = array();
|
$matches = array();
|
||||||
if (preg_match_all('/(?!file|ftp|http|ww)front_content.php\?idcat=([0-9]*)/i', $sValue, $matches)) {
|
if (preg_match_all('/(?!file|ftp|http|ww)front_content.php\?idcat=([0-9]*)/i', $sValue, $matches)) {
|
||||||
for ($i = 0; $i < count($matches[0]); $i++) {
|
for ($i = 0; $i < count($matches[0]); $i++) {
|
||||||
if (!in_array($matches[0][$i], $aWhitelist)) {
|
if (!in_array($matches[0][$i], $aWhitelist)) {
|
||||||
$aSearchIDInfosCat[] = array(
|
$aSearchIDInfosCat[] = array(
|
||||||
|
@ -259,11 +236,11 @@ function searchFrontContentLinks($sValue, $iArt, $sArt, $iCat, $sCat) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// detect urls with parameter idcatart
|
// detect urls with parameter idcatart
|
||||||
$matches = array();
|
$matches = array();
|
||||||
if (preg_match_all('/(?!file|ftp|http|ww)front_content.php\?idcatart=([0-9]*)/i', $sValue, $matches)) { // idcatart
|
if (preg_match_all('/(?!file|ftp|http|ww)front_content.php\?idcatart=([0-9]*)/i', $sValue, $matches)) { // idcatart
|
||||||
for ($i = 0; $i < count($matches[0]); $i++) {
|
for ($i = 0; $i < count($matches[0]); $i++) {
|
||||||
if (!in_array($matches[0][$i], $aWhitelist)) {
|
if (!in_array($matches[0][$i], $aWhitelist)) {
|
||||||
$aSearchIDInfosCatArt[] = array(
|
$aSearchIDInfosCatArt[] = array(
|
||||||
|
@ -271,46 +248,42 @@ function searchFrontContentLinks($sValue, $iArt, $sArt, $iCat, $sCat) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Searchs extern and intern links
|
// Searchs extern and intern links
|
||||||
function searchLinks($sValue, $iArt, $sArt, $iCat, $sCat, $iLang, $sFromtype = "") {
|
function searchLinks($sValue, $iArt, $sArt, $iCat, $sCat, $iLang, $sFromtype = "") {
|
||||||
global $aUrl, $aSearchIDInfosNonID, $aWhitelist;
|
global $aUrl, $aSearchIDInfosNonID, $aWhitelist;
|
||||||
|
|
||||||
// Extern URL
|
// Extern URL
|
||||||
if(preg_match_all('~(?:(?:action|data|href|src)=["\']((?:file|ftp|http|ww)[^\s]*)["\'])~i', $sValue, $aMatches) && $_GET['mode'] != 1) {
|
if (preg_match_all('~(?:(?:action|data|href|src)=["\']((?:file|ftp|http|ww)[^\s]*)["\'])~i', $sValue, $aMatches) && $_GET['mode'] != 1) {
|
||||||
|
|
||||||
for($i = 0; $i < count($aMatches[1]); $i++) {
|
for ($i = 0; $i < count($aMatches[1]); $i++) {
|
||||||
|
|
||||||
if(!in_array($aMatches[1][$i], $aWhitelist)) {
|
if (!in_array($aMatches[1][$i], $aWhitelist)) {
|
||||||
$aSearchIDInfosNonID[] = array("url" => $aMatches[1][$i], "idart" => $iArt, "nameart" => $sArt, "idcat" => $iCat, "namecat" => $sCat, "lang" => $iLang, "urltype" => "extern");
|
$aSearchIDInfosNonID[] = array("url" => $aMatches[1][$i], "idart" => $iArt, "nameart" => $sArt, "idcat" => $iCat, "namecat" => $sCat, "lang" => $iLang, "urltype" => "extern");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
// Redirect
|
||||||
|
if ($sFromtype == "Redirect" && (preg_match('!(' . preg_quote($aUrl['cms']) . '[^\s]*)!i', $sValue, $aMatches)
|
||||||
|
|| (preg_match('~(?:file|ftp|http|ww)[^\s]*~i', $sValue, $aMatches) && $_GET['mode'] != 1))
|
||||||
|
&& (stripos($sValue, 'front_content.php') === false)
|
||||||
|
&& !in_array($aMatches[0], $aWhitelist)) {
|
||||||
|
$aSearchIDInfosNonID[] = array("url" => $aMatches[0], "idart" => $iArt, "nameart" => $sArt, "idcat" => $iCat, "namecat" => $sCat, "lang" => $iLang, "urltype" => "unknown");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
// Intern URL
|
||||||
|
if (preg_match_all('~(?:(?:action|data|href|src)=["\'])(?!file://)(?!ftp://)(?!http://)(?!https://)(?!ww)(?!mailto)(?!\#)(?!/\#)([^"\']+)(?:["\'])~i', $sValue, $aMatches) && $_GET['mode'] != 2) {
|
||||||
|
|
||||||
// Redirect
|
for ($i = 0; $i < count($aMatches[1]); $i++) {
|
||||||
if($sFromtype == "Redirect" && (preg_match('!(' . preg_quote($aUrl['cms']) . '[^\s]*)!i', $sValue, $aMatches)
|
|
||||||
|| (preg_match('~(?:file|ftp|http|ww)[^\s]*~i', $sValue, $aMatches) && $_GET['mode'] != 1))
|
|
||||||
&& (stripos($sValue, 'front_content.php') === false)
|
|
||||||
&& !in_array($aMatches[0], $aWhitelist)) {
|
|
||||||
$aSearchIDInfosNonID[] = array("url" => $aMatches[0], "idart" => $iArt, "nameart" => $sArt, "idcat" => $iCat, "namecat" => $sCat, "lang" => $iLang, "urltype" => "unknown");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Intern URL
|
|
||||||
if(preg_match_all('~(?:(?:action|data|href|src)=["\'])(?!file://)(?!ftp://)(?!http://)(?!https://)(?!ww)(?!mailto)(?!\#)(?!/\#)([^"\']+)(?:["\'])~i', $sValue, $aMatches) && $_GET['mode'] != 2) {
|
|
||||||
|
|
||||||
for($i = 0; $i < count($aMatches[1]); $i++) {
|
|
||||||
|
|
||||||
if(strpos($aMatches[1][$i], "front_content.php") === false && !in_array($aMatches[1][$i], $aWhitelist)) {
|
|
||||||
$aSearchIDInfosNonID[] = array("url" => $aMatches[1][$i], "idart" => $iArt, "nameart" => $sArt, "idcat" => $iCat, "namecat" => $sCat, "lang" => $iLang, "urltype" => "intern");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (strpos($aMatches[1][$i], "front_content.php") === false && !in_array($aMatches[1][$i], $aWhitelist)) {
|
||||||
|
$aSearchIDInfosNonID[] = array("url" => $aMatches[1][$i], "idart" => $iArt, "nameart" => $sArt, "idcat" => $iCat, "namecat" => $sCat, "lang" => $iLang, "urltype" => "intern");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
Laden …
In neuem Issue referenzieren