Commits vergleichen
3 Commits
bugfixes--
...
develop
Autor | SHA1 | Datum | |
---|---|---|---|
|
a00c8149f7 | ||
|
606b832ce8 | ||
|
e9d44453fb |
5 geänderte Dateien mit 51 neuen und 64 gelöschten Zeilen
|
@ -27,6 +27,12 @@ if (!defined('CON_FRAMEWORK')) {
|
||||||
*/
|
*/
|
||||||
class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
||||||
|
|
||||||
|
public $_oView;
|
||||||
|
public $_client;
|
||||||
|
/**
|
||||||
|
* @var array<string, mixed>
|
||||||
|
*/
|
||||||
|
public $_cfg;
|
||||||
/**
|
/**
|
||||||
* Index action
|
* Index action
|
||||||
*/
|
*/
|
||||||
|
@ -41,13 +47,12 @@ class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
||||||
public function saveAction() {
|
public function saveAction() {
|
||||||
$bDebug = $this->getProperty('bDebug');
|
$bDebug = $this->getProperty('bDebug');
|
||||||
$aSeparator = $this->getProperty('aSeparator');
|
$aSeparator = $this->getProperty('aSeparator');
|
||||||
$aWordSeparator = $this->getProperty('aWordSeparator');
|
|
||||||
$routingSeparator = $this->getProperty('routingSeparator');
|
$routingSeparator = $this->getProperty('routingSeparator');
|
||||||
|
|
||||||
$bError = false;
|
$bError = false;
|
||||||
$aMR = array();
|
$aMR = [];
|
||||||
|
|
||||||
$request = (count($_POST) > 0) ? $_POST : $_GET;
|
$request = ($_POST !== []) ? $_POST : $_GET;
|
||||||
mr_requestCleanup($request);
|
mr_requestCleanup($request);
|
||||||
|
|
||||||
// use cl-mod-rewrite
|
// use cl-mod-rewrite
|
||||||
|
@ -321,10 +326,10 @@ class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
||||||
|
|
||||||
// routing
|
// routing
|
||||||
if (isset($request['rewrite_routing'])) {
|
if (isset($request['rewrite_routing'])) {
|
||||||
$aRouting = array();
|
$aRouting = [];
|
||||||
$items = explode("\n", $request['rewrite_routing']);
|
$items = explode("\n", $request['rewrite_routing']);
|
||||||
foreach ($items as $p => $v) {
|
foreach ($items as $item) {
|
||||||
$routingDef = explode($routingSeparator, $v);
|
$routingDef = explode($routingSeparator, $item);
|
||||||
if (count($routingDef) !== 2) {
|
if (count($routingDef) !== 2) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -339,7 +344,7 @@ class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
||||||
$aMR['cl-mod-rewrite']['routing'] = $aRouting;
|
$aMR['cl-mod-rewrite']['routing'] = $aRouting;
|
||||||
} else {
|
} else {
|
||||||
$this->_oView->rewrite_routing = '';
|
$this->_oView->rewrite_routing = '';
|
||||||
$aMR['cl-mod-rewrite']['routing'] = array();
|
$aMR['cl-mod-rewrite']['routing'] = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
// redirect invalid article to errorsite
|
// redirect invalid article to errorsite
|
||||||
|
@ -385,9 +390,8 @@ class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
||||||
/**
|
/**
|
||||||
* Checks, if any sseparators setting is modified or not
|
* Checks, if any sseparators setting is modified or not
|
||||||
* @param array $aNewCfg New configuration send by requests.
|
* @param array $aNewCfg New configuration send by requests.
|
||||||
* @return bool
|
|
||||||
*/
|
*/
|
||||||
protected function _separatorModified($aNewCfg) {
|
protected function _separatorModified($aNewCfg): bool {
|
||||||
$aCfg = ModRewrite::getConfig();
|
$aCfg = ModRewrite::getConfig();
|
||||||
|
|
||||||
if ($aCfg['category_seperator'] != $aNewCfg['category_seperator']) {
|
if ($aCfg['category_seperator'] != $aNewCfg['category_seperator']) {
|
||||||
|
@ -405,18 +409,19 @@ class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
|
||||||
/**
|
/**
|
||||||
* Does some checks like 'is_start_compatible' check.
|
* Does some checks like 'is_start_compatible' check.
|
||||||
* Adds notifications, if something will went wrong...
|
* Adds notifications, if something will went wrong...
|
||||||
|
*
|
||||||
|
* @todo review text and translations
|
||||||
*/
|
*/
|
||||||
protected function _doChecks() {
|
protected function _doChecks() {
|
||||||
// Check for not supported '$cfg["is_start_compatible"] = true;' mode
|
|
||||||
if (!empty($this->_cfg['is_start_compatible']) && true === $this->_cfg['is_start_compatible']) {
|
if (!empty($this->_cfg['is_start_compatible']) && true === $this->_cfg['is_start_compatible']) {
|
||||||
$sMsg = i18n("Your Contenido installation runs with the setting 'is_start_compatible'. This plugin will not work properly in this mode.<br />Please check following topic in Contenido forum to change this:<br /><br /><a href='http://forum.contenido.org/viewtopic.php?t=32530' class='blue' target='_blank'>is_start_compatible auf neue Version umstellen</a>", "cl-mod-rewrite");
|
$sMsg = i18n("Your Contenido installation runs with the setting 'is_start_compatible'. This plugin will not work properly in this mode.<br />Please check following topic in Contenido forum to change this:<br /><br /><a href='http://forum.contenido.org/viewtopic.php?t=32530' class='blue' target='_blank'>is_start_compatible auf neue Version umstellen</a>", "cl-mod-rewrite");
|
||||||
$this->_oView->content_before .= $this->_notifyBox('warning', $sMsg);
|
$this->_oView->content_before .= $this->_notifyBox('warning', $sMsg);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for empty urlpath entries in cat_lang table
|
// Check for empty urlpath entries in cat_lang table
|
||||||
$db = new DB_Contenido();
|
$dbConLite = new DB_ConLite();
|
||||||
$sql = "SELECT idcatlang FROM " . $this->_cfg['tab']['cat_lang'] . " WHERE urlpath = ''";
|
$sql = "SELECT idcatlang FROM " . $this->_cfg['tab']['cat_lang'] . " WHERE urlpath = ''";
|
||||||
if ($db->query($sql) && $db->next_record()) {
|
if ($dbConLite->query($sql) && $dbConLite->next_record()) {
|
||||||
$sMsg = i18n("It seems as if some categories don't have a set 'urlpath' entry in the database. Please reset empty aliases in %sFunctions%s area.", "cl-mod-rewrite");
|
$sMsg = i18n("It seems as if some categories don't have a set 'urlpath' entry in the database. Please reset empty aliases in %sFunctions%s area.", "cl-mod-rewrite");
|
||||||
$sMsg = sprintf($sMsg, '<a href="main.php?area=mod_rewrite_expert&frame=4&contenido=' . $this->_oView->sessid . '&idclient=' . $this->_client . '" onclick="parent.right_top.sub.clicked(parent.right_top.document.getElementById(\'c_1\').firstChild);">', '</a>');
|
$sMsg = sprintf($sMsg, '<a href="main.php?area=mod_rewrite_expert&frame=4&contenido=' . $this->_oView->sessid . '&idclient=' . $this->_client . '" onclick="parent.right_top.sub.clicked(parent.right_top.document.getElementById(\'c_1\').firstChild);">', '</a>');
|
||||||
$this->_oView->content_before .= $this->_notifyBox('warning', $sMsg);
|
$this->_oView->content_before .= $this->_notifyBox('warning', $sMsg);
|
||||||
|
|
|
@ -77,17 +77,9 @@ class ModRewrite_ContentExpertController extends ModRewrite_ControllerAbstract {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($type == 'restrictive') {
|
$source = $type == 'restrictive' ? $this->_htaccessRestrictive : $this->_htaccessSimple;
|
||||||
$source = $this->_htaccessRestrictive;
|
|
||||||
} else {
|
|
||||||
$source = $this->_htaccessSimple;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($copy == 'contenido') {
|
$dest = $copy == 'contenido' ? $aInfo['contenido_full_path'] . '.htaccess' : $aInfo['client_full_path'] . '.htaccess';
|
||||||
$dest = $aInfo['contenido_full_path'] . '.htaccess';
|
|
||||||
} else {
|
|
||||||
$dest = $aInfo['client_full_path'] . '.htaccess';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$result = @copy($source, $dest)) {
|
if (!$result = @copy($source, $dest)) {
|
||||||
$this->_oView->content_before = $this->_notifyBox('info', 'Die .htaccess konnte nicht von ' . $source . ' nach ' . $dest . ' kopiert werden!');
|
$this->_oView->content_before = $this->_notifyBox('info', 'Die .htaccess konnte nicht von ' . $source . ' nach ' . $dest . ' kopiert werden!');
|
||||||
|
@ -108,16 +100,12 @@ class ModRewrite_ContentExpertController extends ModRewrite_ControllerAbstract {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($type == 'restrictive') {
|
$source = $type == 'restrictive' ? $this->_htaccessRestrictive : $this->_htaccessSimple;
|
||||||
$source = $this->_htaccessRestrictive;
|
|
||||||
} else {
|
|
||||||
$source = $this->_htaccessSimple;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->_oView->content = file_get_contents($source);
|
$this->_oView->content = file_get_contents($source);
|
||||||
|
|
||||||
header('Content-Type: text/plain');
|
header('Content-Type: text/plain');
|
||||||
header('Etag: ' . md5(mt_rand()));
|
header('Etag: ' . md5(random_int(0, mt_getrandmax())));
|
||||||
header('Content-Disposition: attachment; filename="' . $type . '.htaccess"');
|
header('Content-Disposition: attachment; filename="' . $type . '.htaccess"');
|
||||||
$this->render('{CONTENT}');
|
$this->render('{CONTENT}');
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,33 +60,25 @@ class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
|
||||||
$this->_oView->content = '';
|
$this->_oView->content = '';
|
||||||
|
|
||||||
// Array for testcases
|
// Array for testcases
|
||||||
$aTests = array();
|
$aTests = [];
|
||||||
|
|
||||||
// Instance of mr test
|
// Instance of mr test
|
||||||
$oMRTest = new ModRewriteTest($this->_iMaxItems);
|
$modRewriteTest = new ModRewriteTest($this->_iMaxItems);
|
||||||
|
|
||||||
$startTime = getmicrotime();
|
$startTime = getmicrotime();
|
||||||
|
|
||||||
// Fetch complete CONTENIDO page structure
|
// Fetch complete CONTENIDO page structure
|
||||||
$aStruct = $oMRTest->fetchFullStructure();
|
$aStruct = $modRewriteTest->fetchFullStructure();
|
||||||
ModRewriteDebugger::add($aStruct, 'ModRewrite_ContentTestController::testAction() $aStruct');
|
ModRewriteDebugger::add($aStruct, 'ModRewrite_ContentTestController::testAction() $aStruct');
|
||||||
|
|
||||||
// Loop through the structure and compose testcases
|
// Loop through the structure and compose testcases
|
||||||
foreach ($aStruct as $idcat => $aCat) {
|
foreach ($aStruct as $aCat) {
|
||||||
// category
|
// category
|
||||||
$aTests[] = array(
|
$aTests[] = ['url' => $modRewriteTest->composeURL($aCat, 'c'), 'level' => $aCat['level'], 'name' => $aCat['name']];
|
||||||
'url' => $oMRTest->composeURL($aCat, 'c'),
|
|
||||||
'level' => $aCat['level'],
|
|
||||||
'name' => $aCat['name']
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($aCat['articles'] as $idart => $aArt) {
|
foreach ($aCat['articles'] as $aArt) {
|
||||||
// articles
|
// articles
|
||||||
$aTests[] = array(
|
$aTests[] = ['url' => $modRewriteTest->composeURL($aArt, 'a'), 'level' => $aCat['level'], 'name' => $aCat['name'] . ' :: ' . $aArt['title']];
|
||||||
'url' => $oMRTest->composeURL($aArt, 'a'),
|
|
||||||
'level' => $aCat['level'],
|
|
||||||
'name' => $aCat['name'] . ' :: ' . $aArt['title']
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +88,7 @@ class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
|
||||||
$oMRUrlStack = ModRewriteUrlStack::getInstance();
|
$oMRUrlStack = ModRewriteUrlStack::getInstance();
|
||||||
|
|
||||||
// first loop to add urls to mr url stack
|
// first loop to add urls to mr url stack
|
||||||
foreach ($aTests as $p => $v) {
|
foreach ($aTests as $v) {
|
||||||
$oMRUrlStack->add($v['url']);
|
$oMRUrlStack->add($v['url']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,15 +96,15 @@ class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
|
||||||
$failCounter = 0;
|
$failCounter = 0;
|
||||||
|
|
||||||
// second loop to do the rest
|
// second loop to do the rest
|
||||||
foreach ($aTests as $p => $v) {
|
foreach ($aTests as $aTest) {
|
||||||
$url = mr_buildNewUrl($v['url']);
|
$url = mr_buildNewUrl($aTest['url']);
|
||||||
$arr = $oMRTest->resolveUrl($url);
|
$arr = $modRewriteTest->resolveUrl($url);
|
||||||
$error = '';
|
$error = '';
|
||||||
$resUrl = $oMRTest->getResolvedUrl();
|
$resUrl = $modRewriteTest->getResolvedUrl();
|
||||||
$color = 'green';
|
$color = 'green';
|
||||||
|
|
||||||
if ($url !== $resUrl) {
|
if ($url !== $resUrl) {
|
||||||
if ($oMRTest->getRoutingFoundState()) {
|
if ($modRewriteTest->getRoutingFoundState()) {
|
||||||
$successCounter++;
|
$successCounter++;
|
||||||
$resUrl = 'route to -> ' . $resUrl;
|
$resUrl = 'route to -> ' . $resUrl;
|
||||||
} else {
|
} else {
|
||||||
|
@ -144,18 +136,18 @@ class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$pref = str_repeat(' ', $v['level']);
|
$pref = str_repeat(' ', $aTest['level']);
|
||||||
|
|
||||||
// render resolve information for current item
|
// render resolve information for current item
|
||||||
$itemTpl = $this->_oView->lng_result_item_tpl;
|
$itemTpl = $this->_oView->lng_result_item_tpl;
|
||||||
$itemTpl = str_replace('{pref}', $pref, $itemTpl);
|
$itemTpl = str_replace('{pref}', $pref, $itemTpl);
|
||||||
$itemTpl = str_replace('{name}', $v['name'], $itemTpl);
|
$itemTpl = str_replace('{name}', $aTest['name'], $itemTpl);
|
||||||
$itemTpl = str_replace('{url_in}', $v['url'], $itemTpl);
|
$itemTpl = str_replace('{url_in}', $aTest['url'], $itemTpl);
|
||||||
$itemTpl = str_replace('{url_out}', $url, $itemTpl);
|
$itemTpl = str_replace('{url_out}', $url, $itemTpl);
|
||||||
$itemTpl = str_replace('{color}', $color, $itemTpl);
|
$itemTpl = str_replace('{color}', $color, $itemTpl);
|
||||||
$itemTpl = str_replace('{url_res}', $resUrl, $itemTpl);
|
$itemTpl = str_replace('{url_res}', $resUrl, $itemTpl);
|
||||||
$itemTpl = str_replace('{err}', $error, $itemTpl);
|
$itemTpl = str_replace('{err}', $error, $itemTpl);
|
||||||
$itemTpl = str_replace('{data}', $oMRTest->getReadableResolvedData($arr), $itemTpl);
|
$itemTpl = str_replace('{data}', $modRewriteTest->getReadableResolvedData($arr), $itemTpl);
|
||||||
|
|
||||||
$this->_oView->content .= "\n" . $itemTpl . "\n";
|
$this->_oView->content .= "\n" . $itemTpl . "\n";
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,13 +72,13 @@ abstract class ModRewrite_ControllerAbstract {
|
||||||
* Template file or template string to render
|
* Template file or template string to render
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected $_template = null;
|
protected $_template;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Additional properties list
|
* Additional properties list
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected $_properties = array();
|
protected $_properties = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug flag
|
* Debug flag
|
||||||
|
@ -138,20 +138,18 @@ abstract class ModRewrite_ControllerAbstract {
|
||||||
/**
|
/**
|
||||||
* Property setter.
|
* Property setter.
|
||||||
* @param string $key
|
* @param string $key
|
||||||
* @param mixed $value
|
|
||||||
*/
|
*/
|
||||||
public function setProperty($key, $value) {
|
public function setProperty($key, mixed $value) {
|
||||||
$this->_properties[$key] = $value;
|
$this->_properties[$key] = $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Property getter.
|
* Property getter.
|
||||||
* @param string $key
|
* @param string $key
|
||||||
* @param mixed $default
|
|
||||||
* @return mixed
|
* @return mixed
|
||||||
*/
|
*/
|
||||||
public function getProperty($key, $default = null) {
|
public function getProperty($key, mixed $default = null) {
|
||||||
return (isset($this->_properties[$key])) ? $this->_properties[$key] : $default;
|
return $this->_properties[$key] ?? $default;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -202,7 +200,7 @@ abstract class ModRewrite_ControllerAbstract {
|
||||||
* @param mixed $default The default value
|
* @param mixed $default The default value
|
||||||
* @return mixed
|
* @return mixed
|
||||||
*/
|
*/
|
||||||
protected function _getParam($key, $default = null) {
|
protected function _getParam($key, mixed $default = null) {
|
||||||
if (isset($_GET[$key])) {
|
if (isset($_GET[$key])) {
|
||||||
return $_GET[$key];
|
return $_GET[$key];
|
||||||
} elseif (isset($_POST[$key])) {
|
} elseif (isset($_POST[$key])) {
|
||||||
|
|
|
@ -23,6 +23,10 @@
|
||||||
* @link http://www.4fb.de
|
* @link http://www.4fb.de
|
||||||
* @link http://www.contenido.org
|
* @link http://www.contenido.org
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
use ConLite\Log\LogWriter;
|
||||||
|
use ConLite\Log\Log;
|
||||||
|
|
||||||
if (!defined('CON_FRAMEWORK')) {
|
if (!defined('CON_FRAMEWORK')) {
|
||||||
die('Illegal call');
|
die('Illegal call');
|
||||||
}
|
}
|
||||||
|
@ -679,9 +683,9 @@ function mr_setConfiguration($clientId, array $config) {
|
||||||
try {
|
try {
|
||||||
mkdir($sConfigClientPath, 0777, true);
|
mkdir($sConfigClientPath, 0777, true);
|
||||||
} catch (Exception $ex) {
|
} catch (Exception $ex) {
|
||||||
$oWriter = cLogWriter::factory("File", array('destination' => 'contenido.log'));
|
$writer = LogWriter::factory("File", array('destination' => 'contenido.log'));
|
||||||
$oLog = new cLog($oWriter);
|
$log = new Log($writer);
|
||||||
$oLog->log($ex->getFile() . " (" . $ex->getLine() . "): " . $ex->getMessage(), cLog::WARN);
|
$log->log($ex->getFile() . " (" . $ex->getLine() . "): " . $ex->getMessage(), Log::WARN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Laden …
In neuem Issue referenzieren