1
0
Fork 0

Commits vergleichen

..

Keine gemeinsamen Commits. „develop“ und „bugfixes--V1“ haben vollständig unterschiedliche Historien.

5 geänderte Dateien mit 64 neuen und 51 gelöschten Zeilen

Datei anzeigen

@ -27,12 +27,6 @@ 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
*/ */
@ -47,12 +41,13 @@ 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 = []; $aMR = array();
$request = ($_POST !== []) ? $_POST : $_GET; $request = (count($_POST) > 0) ? $_POST : $_GET;
mr_requestCleanup($request); mr_requestCleanup($request);
// use cl-mod-rewrite // use cl-mod-rewrite
@ -326,10 +321,10 @@ class ModRewrite_ContentController extends ModRewrite_ControllerAbstract {
// routing // routing
if (isset($request['rewrite_routing'])) { if (isset($request['rewrite_routing'])) {
$aRouting = []; $aRouting = array();
$items = explode("\n", $request['rewrite_routing']); $items = explode("\n", $request['rewrite_routing']);
foreach ($items as $item) { foreach ($items as $p => $v) {
$routingDef = explode($routingSeparator, $item); $routingDef = explode($routingSeparator, $v);
if (count($routingDef) !== 2) { if (count($routingDef) !== 2) {
continue; continue;
} }
@ -344,7 +339,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'] = []; $aMR['cl-mod-rewrite']['routing'] = array();
} }
// redirect invalid article to errorsite // redirect invalid article to errorsite
@ -390,8 +385,9 @@ 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): bool { protected function _separatorModified($aNewCfg) {
$aCfg = ModRewrite::getConfig(); $aCfg = ModRewrite::getConfig();
if ($aCfg['category_seperator'] != $aNewCfg['category_seperator']) { if ($aCfg['category_seperator'] != $aNewCfg['category_seperator']) {
@ -409,19 +405,18 @@ 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
$dbConLite = new DB_ConLite(); $db = new DB_Contenido();
$sql = "SELECT idcatlang FROM " . $this->_cfg['tab']['cat_lang'] . " WHERE urlpath = ''"; $sql = "SELECT idcatlang FROM " . $this->_cfg['tab']['cat_lang'] . " WHERE urlpath = ''";
if ($dbConLite->query($sql) && $dbConLite->next_record()) { if ($db->query($sql) && $db->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);

Datei anzeigen

@ -77,9 +77,17 @@ class ModRewrite_ContentExpertController extends ModRewrite_ControllerAbstract {
return; return;
} }
$source = $type == 'restrictive' ? $this->_htaccessRestrictive : $this->_htaccessSimple; if ($type == 'restrictive') {
$source = $this->_htaccessRestrictive;
} else {
$source = $this->_htaccessSimple;
}
$dest = $copy == 'contenido' ? $aInfo['contenido_full_path'] . '.htaccess' : $aInfo['client_full_path'] . '.htaccess'; if ($copy == 'contenido') {
$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!');
@ -100,12 +108,16 @@ class ModRewrite_ContentExpertController extends ModRewrite_ControllerAbstract {
return; return;
} }
$source = $type == 'restrictive' ? $this->_htaccessRestrictive : $this->_htaccessSimple; if ($type == 'restrictive') {
$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(random_int(0, mt_getrandmax()))); header('Etag: ' . md5(mt_rand()));
header('Content-Disposition: attachment; filename="' . $type . '.htaccess"'); header('Content-Disposition: attachment; filename="' . $type . '.htaccess"');
$this->render('{CONTENT}'); $this->render('{CONTENT}');
} }

Datei anzeigen

@ -60,25 +60,33 @@ class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
$this->_oView->content = ''; $this->_oView->content = '';
// Array for testcases // Array for testcases
$aTests = []; $aTests = array();
// Instance of mr test // Instance of mr test
$modRewriteTest = new ModRewriteTest($this->_iMaxItems); $oMRTest = new ModRewriteTest($this->_iMaxItems);
$startTime = getmicrotime(); $startTime = getmicrotime();
// Fetch complete CONTENIDO page structure // Fetch complete CONTENIDO page structure
$aStruct = $modRewriteTest->fetchFullStructure(); $aStruct = $oMRTest->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 $aCat) { foreach ($aStruct as $idcat => $aCat) {
// category // category
$aTests[] = ['url' => $modRewriteTest->composeURL($aCat, 'c'), 'level' => $aCat['level'], 'name' => $aCat['name']]; $aTests[] = array(
'url' => $oMRTest->composeURL($aCat, 'c'),
'level' => $aCat['level'],
'name' => $aCat['name']
);
foreach ($aCat['articles'] as $aArt) { foreach ($aCat['articles'] as $idart => $aArt) {
// articles // articles
$aTests[] = ['url' => $modRewriteTest->composeURL($aArt, 'a'), 'level' => $aCat['level'], 'name' => $aCat['name'] . ' :: ' . $aArt['title']]; $aTests[] = array(
'url' => $oMRTest->composeURL($aArt, 'a'),
'level' => $aCat['level'],
'name' => $aCat['name'] . ' :: ' . $aArt['title']
);
} }
} }
@ -88,7 +96,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 $v) { foreach ($aTests as $p => $v) {
$oMRUrlStack->add($v['url']); $oMRUrlStack->add($v['url']);
} }
@ -96,15 +104,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 $aTest) { foreach ($aTests as $p => $v) {
$url = mr_buildNewUrl($aTest['url']); $url = mr_buildNewUrl($v['url']);
$arr = $modRewriteTest->resolveUrl($url); $arr = $oMRTest->resolveUrl($url);
$error = ''; $error = '';
$resUrl = $modRewriteTest->getResolvedUrl(); $resUrl = $oMRTest->getResolvedUrl();
$color = 'green'; $color = 'green';
if ($url !== $resUrl) { if ($url !== $resUrl) {
if ($modRewriteTest->getRoutingFoundState()) { if ($oMRTest->getRoutingFoundState()) {
$successCounter++; $successCounter++;
$resUrl = 'route to -&gt; ' . $resUrl; $resUrl = 'route to -&gt; ' . $resUrl;
} else { } else {
@ -136,18 +144,18 @@ class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
} }
} }
$pref = str_repeat(' ', $aTest['level']); $pref = str_repeat(' ', $v['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}', $aTest['name'], $itemTpl); $itemTpl = str_replace('{name}', $v['name'], $itemTpl);
$itemTpl = str_replace('{url_in}', $aTest['url'], $itemTpl); $itemTpl = str_replace('{url_in}', $v['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}', $modRewriteTest->getReadableResolvedData($arr), $itemTpl); $itemTpl = str_replace('{data}', $oMRTest->getReadableResolvedData($arr), $itemTpl);
$this->_oView->content .= "\n" . $itemTpl . "\n"; $this->_oView->content .= "\n" . $itemTpl . "\n";
} }

Datei anzeigen

@ -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; protected $_template = null;
/** /**
* Additional properties list * Additional properties list
* @var array * @var array
*/ */
protected $_properties = []; protected $_properties = array();
/** /**
* Debug flag * Debug flag
@ -138,18 +138,20 @@ abstract class ModRewrite_ControllerAbstract {
/** /**
* Property setter. * Property setter.
* @param string $key * @param string $key
* @param mixed $value
*/ */
public function setProperty($key, mixed $value) { public function setProperty($key, $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, mixed $default = null) { public function getProperty($key, $default = null) {
return $this->_properties[$key] ?? $default; return (isset($this->_properties[$key])) ? $this->_properties[$key] : $default;
} }
/** /**
@ -200,7 +202,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, mixed $default = null) { protected function _getParam($key, $default = null) {
if (isset($_GET[$key])) { if (isset($_GET[$key])) {
return $_GET[$key]; return $_GET[$key];
} elseif (isset($_POST[$key])) { } elseif (isset($_POST[$key])) {

Datei anzeigen

@ -23,10 +23,6 @@
* @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');
} }
@ -683,9 +679,9 @@ function mr_setConfiguration($clientId, array $config) {
try { try {
mkdir($sConfigClientPath, 0777, true); mkdir($sConfigClientPath, 0777, true);
} catch (Exception $ex) { } catch (Exception $ex) {
$writer = LogWriter::factory("File", array('destination' => 'contenido.log')); $oWriter = cLogWriter::factory("File", array('destination' => 'contenido.log'));
$log = new Log($writer); $oLog = new cLog($oWriter);
$log->log($ex->getFile() . " (" . $ex->getLine() . "): " . $ex->getMessage(), Log::WARN); $oLog->log($ex->getFile() . " (" . $ex->getLine() . "): " . $ex->getMessage(), cLog::WARN);
} }
} }