Merge branch 'develop' of https://oldperl@gitport.de/ConLite/ConLite.git into develop
Conflicts: .gitignore setup/lib/defines.php setup/lib/startup.php
Dieser Commit ist enthalten in:
Commit
b3e921255c
|
@ -4,8 +4,8 @@
|
|||
/conlite/plugins/pluginmanager/_src/
|
||||
/.project
|
||||
/_api/
|
||||
/cl-releasetool/
|
||||
/data/cache/edit_area_full_with_plugins.gz
|
||||
/data/cache/edit_area_full_with_plugins.js
|
||||
/data/config/production/config.local.php
|
||||
/cms/data/modules/up-download/
|
||||
/cl-releasetool/
|
||||
|
|
|
@ -0,0 +1,61 @@
|
|||
################################################################################
|
||||
# ConLite AMR plugin simple rewrite rules set.
|
||||
#
|
||||
# Contains few easy to handle rewrite rules.
|
||||
#
|
||||
# @version 1.0.0
|
||||
# @author Ortwin Pinke <ortwin.pinke@php-backoffice.de>
|
||||
# @author Murat Purc <murat@purc.de>
|
||||
# @copyright 2019 ConLite Team
|
||||
# @link http://www.conlite.org
|
||||
#
|
||||
# Versions before 1.0 copyright 4fb, author Murat Purc
|
||||
#
|
||||
# $Id: htaccess_simple.txt 145 2019-10-25 16:00:47Z oldperl $
|
||||
################################################################################
|
||||
|
||||
#SetEnv CONLITE_ENVIRONMENT development
|
||||
|
||||
<IfModule mod_rewrite.c>
|
||||
|
||||
# Enable rewrite engine
|
||||
RewriteEngine on
|
||||
|
||||
# Specify a base URL-path for the rules
|
||||
RewriteBase /cms
|
||||
|
||||
# Catch some common exploits in query string to get rid of them
|
||||
# NOTE: Conditions to prevent protocols (ftp, http[s]) in query string could
|
||||
# be a disadvantage in some cases
|
||||
RewriteCond %{QUERY_STRING} contenido_path=.*$ [NC,OR]
|
||||
RewriteCond %{QUERY_STRING} cfg\[path\]=.*$ [NC,OR]
|
||||
RewriteCond %{QUERY_STRING} _PHPLIB\[libdir\]=.*$ [NC,OR]
|
||||
RewriteCond %{QUERY_STRING} (\<|%3C).*script.*(\>|%3E) [NC,OR]
|
||||
RewriteCond %{QUERY_STRING} ftp://.*$ [NC,OR]
|
||||
RewriteCond %{QUERY_STRING} http[s]*://.*$ [NC]
|
||||
RewriteRule ^.* - [F,L] # all matching conditions from above will end in nirvana
|
||||
|
||||
# Rewrite request to root to front_content.php
|
||||
RewriteRule ^$ front_content.php [QSA,L]
|
||||
|
||||
# Exclude following request from rewriting
|
||||
# tests for favicon.ico, valid symlinks (-s), not empty files (-l) and folders (-d)
|
||||
RewriteCond %{REQUEST_URI} ^/favicon.ico$ [OR]
|
||||
RewriteCond %{REQUEST_FILENAME} -s [OR]
|
||||
RewriteCond %{REQUEST_FILENAME} -l [OR]
|
||||
RewriteCond %{REQUEST_FILENAME} -d
|
||||
RewriteRule ^.*$ - [NC,L]
|
||||
|
||||
# Pass other requests to front_content.php
|
||||
RewriteRule ^.*$ front_content.php [QSA,NC,L]
|
||||
|
||||
</IfModule>
|
||||
|
||||
# Some rules to compress files.
|
||||
# NOTE: Following settings are not mod rewrite specific, but enabling mod_deflate
|
||||
# for some file types can help to reduce bandwith.
|
||||
<IfModule mod_deflate.c>
|
||||
<FilesMatch "\.(js|css|html|htm|php|xml)$">
|
||||
SetOutputFilter DEFLATE
|
||||
</FilesMatch>
|
||||
</IfModule>
|
|
@ -1,4 +1,5 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* Project:
|
||||
* Contenido Content Management System
|
||||
|
@ -26,14 +27,13 @@
|
|||
*
|
||||
* $Id$:
|
||||
*/
|
||||
|
||||
if (!defined('CON_FRAMEWORK')) {
|
||||
die('Illegal call');
|
||||
}
|
||||
|
||||
// Select box with additional functions for category and article selection
|
||||
class cHTMLInputSelectElement extends cHTMLSelectElement
|
||||
{
|
||||
class cHTMLInputSelectElement extends cHTMLSelectElement {
|
||||
|
||||
/**
|
||||
* Constructor. Creates an HTML select field (aka "DropDown").
|
||||
*
|
||||
|
@ -46,12 +46,10 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
*
|
||||
* @return none
|
||||
* */
|
||||
function __construct ($sName, $iWidth = "", $sID = "", $bDisabled = false, $iTabIndex = null, $sAccessKey = "")
|
||||
{
|
||||
function __construct($sName, $iWidth = "", $sID = "", $bDisabled = false, $iTabIndex = null, $sAccessKey = "") {
|
||||
cHTMLSelectElement :: __construct($sName, $iWidth, $sID, $bDisabled, $iTabIndex, $sAccessKey);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Function addArticles. Adds articles to select box values.
|
||||
*
|
||||
|
@ -62,14 +60,12 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
*
|
||||
* @return int Number of items added
|
||||
* */
|
||||
function addArticles ($iIDCat, $bColored = false, $bArtOnline = true, $sSpaces = "")
|
||||
{
|
||||
function addArticles($iIDCat, $bColored = false, $bArtOnline = true, $sSpaces = "") {
|
||||
global $cfg, $lang;
|
||||
|
||||
$oDB = new DB_Contenido;
|
||||
|
||||
if (is_numeric($iIDCat) && $iIDCat > 0)
|
||||
{
|
||||
if (is_numeric($iIDCat) && $iIDCat > 0) {
|
||||
$sSQL = "SELECT tblArtLang.title AS title, tblArtLang.idartlang AS idartlang, tblCatArt.idcat AS idcat, ";
|
||||
$sSQL .= "tblCatArt.idcatart AS idcatart, tblCatArt.is_start AS isstart, tblArtLang.online AS online, ";
|
||||
$sSQL .= "tblCatLang.startidartlang as idstartartlang ";
|
||||
|
@ -95,13 +91,11 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
return 0;
|
||||
} else {
|
||||
$iCounter = count($this->_options);
|
||||
while ($oDB->next_record())
|
||||
{
|
||||
while ($oDB->next_record()) {
|
||||
// Generate new option element
|
||||
$oOption = new cHTMLOptionElement($sSpaces . " " . substr(urldecode($oDB->f("title")), 0, 32), $oDB->f("idcatart"));
|
||||
|
||||
if ($bColored)
|
||||
{
|
||||
if ($bColored) {
|
||||
$bIsStartArticle = false;
|
||||
if ($cfg["is_start_compatible"] == true && $oDB->f("isstart") == 1) {
|
||||
// Compatible mode and "start article" flag is set
|
||||
|
@ -111,8 +105,7 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
$bIsStartArticle = true;
|
||||
}
|
||||
|
||||
if ($bIsStartArticle)
|
||||
{
|
||||
if ($bIsStartArticle) {
|
||||
if ($oDB->f("online") == 0) {
|
||||
// Start article, but offline -> red
|
||||
$oOption->setStyle("color: #ff0000;");
|
||||
|
@ -152,8 +145,7 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
* @return int Number of items added
|
||||
* */
|
||||
function addCategories($iMaxLevel = 0, $bColored = false, $bCatVisible = true, $bCatPublic = true,
|
||||
$bWithArt = false, $bArtOnline = true)
|
||||
{
|
||||
$bWithArt = false, $bArtOnline = true) {
|
||||
global $cfg, $client, $lang;
|
||||
|
||||
$oDB = new DB_Contenido;
|
||||
|
@ -177,8 +169,7 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
return false;
|
||||
} else {
|
||||
$iCounter = count($this->_options);
|
||||
while ($oDB->next_record())
|
||||
{
|
||||
while ($oDB->next_record()) {
|
||||
$sSpaces = "";
|
||||
$sStyle = "";
|
||||
$iID = $oDB->f("idcat");
|
||||
|
@ -188,8 +179,7 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
}
|
||||
|
||||
// Generate new option element
|
||||
if (($bCatVisible && $oDB->f("visible") == 0) ||
|
||||
($bCatPublic && $oDB->f("public") == 0)) {
|
||||
if (($bCatVisible && $oDB->f("visible") == 0) || ($bCatPublic && $oDB->f("public") == 0)) {
|
||||
// If category has to be visible or public and it isn't, don't add value
|
||||
$sValue = "";
|
||||
} else if ($bWithArt) {
|
||||
|
@ -228,14 +218,12 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
*
|
||||
* @return int Number of items added
|
||||
* */
|
||||
function addTypesFromArt ($iIDCatArt, $sTypeRange = "")
|
||||
{
|
||||
function addTypesFromArt($iIDCatArt, $sTypeRange = "") {
|
||||
global $cfg, $lang;
|
||||
|
||||
$oDB = new DB_Contenido;
|
||||
|
||||
if (is_numeric($iIDCatArt) && $iIDCatArt > 0)
|
||||
{
|
||||
if (is_numeric($iIDCatArt) && $iIDCatArt > 0) {
|
||||
$sSQL = "SELECT tblContent.typeid AS typeid, tblContent.idtype AS idtype, tblType.type AS type, tblType.description AS description, ";
|
||||
$sSQL .= "tblContent.value AS value ";
|
||||
$sSQL .= "FROM " . $cfg["tab"]["content"] . " AS tblContent, " . $cfg["tab"]["art_lang"] . " AS tblArtLang, ";
|
||||
|
@ -255,8 +243,7 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
if ($iCount == 0) {
|
||||
return false;
|
||||
} else {
|
||||
while ($oDB->next_record())
|
||||
{
|
||||
while ($oDB->next_record()) {
|
||||
$sTypeIdentifier = "tblData.idtype = '" . $oDB->f('idtype') . "' AND tblData.typeid = '" . $oDB->f('typeid') . "'";
|
||||
|
||||
// Generate new option element
|
||||
|
@ -279,14 +266,10 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
*
|
||||
* @return none
|
||||
*/
|
||||
function setSelected($aElements)
|
||||
{
|
||||
if (is_array($this->_options) && is_array($aElements))
|
||||
{
|
||||
foreach ($this->_options as $sKey => $oOption)
|
||||
{
|
||||
if (in_array($oOption->getAttribute("value"), $aElements))
|
||||
{
|
||||
function setSelected($aElements) {
|
||||
if (is_array($this->_options) && is_array($aElements)) {
|
||||
foreach ($this->_options as $sKey => $oOption) {
|
||||
if (in_array($oOption->getAttribute("value"), $aElements)) {
|
||||
$oOption->setSelected(true);
|
||||
$this->_options[$sKey] = $oOption;
|
||||
} else {
|
||||
|
@ -296,13 +279,13 @@ class cHTMLInputSelectElement extends cHTMLSelectElement
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
class UI_Config_Table
|
||||
{
|
||||
class UI_Config_Table {
|
||||
|
||||
var $_sTplCellCode;
|
||||
var $_sTplTableFile;
|
||||
|
||||
var $_sWidth;
|
||||
var $_sBorder;
|
||||
var $_sBorderColor;
|
||||
|
@ -316,12 +299,10 @@ class UI_Config_Table
|
|||
var $_aRowBgColor;
|
||||
var $_aRowExtra;
|
||||
var $_bAddMultiSelJS;
|
||||
|
||||
var $_sColorLight;
|
||||
var $_sColorDark;
|
||||
|
||||
function __construct()
|
||||
{
|
||||
function __construct() {
|
||||
global $cfg;
|
||||
|
||||
$this->_sPadding = 2;
|
||||
|
@ -333,98 +314,78 @@ class UI_Config_Table
|
|||
$this->_sColorDark = $cfg['color']['table_dark'];
|
||||
}
|
||||
|
||||
function setCellTemplate($sCode)
|
||||
{
|
||||
function setCellTemplate($sCode) {
|
||||
$this->_sTplCellCode = $sCode;
|
||||
}
|
||||
|
||||
|
||||
function setTableTemplateFile($sPath)
|
||||
{
|
||||
function setTableTemplateFile($sPath) {
|
||||
$this->_sTplTableFile = $sPath;
|
||||
}
|
||||
|
||||
function setLightColor($sColor)
|
||||
{
|
||||
function setLightColor($sColor) {
|
||||
$this->_sColorLight = $sColor;
|
||||
}
|
||||
|
||||
function setDarkColor($sColor)
|
||||
{
|
||||
function setDarkColor($sColor) {
|
||||
$this->_sColorDark = $sColor;
|
||||
}
|
||||
|
||||
function setAddMultiSelJS($bEnabled = true)
|
||||
{
|
||||
function setAddMultiSelJS($bEnabled = true) {
|
||||
$this->_bAddMultiSelJS = (bool) $bEnabled;
|
||||
}
|
||||
|
||||
function setWidth ($sWidth)
|
||||
{
|
||||
function setWidth($sWidth) {
|
||||
$this->_sWidth = $sWidth;
|
||||
}
|
||||
|
||||
function setPadding ($sPadding)
|
||||
{
|
||||
function setPadding($sPadding) {
|
||||
$this->_sPadding = $sPadding;
|
||||
}
|
||||
|
||||
function setBorder ($sBorder)
|
||||
{
|
||||
function setBorder($sBorder) {
|
||||
$this->_sBorder = $sBorder;
|
||||
}
|
||||
|
||||
function setBorderColor ($sBorderColor)
|
||||
{
|
||||
function setBorderColor($sBorderColor) {
|
||||
$this->_sBorderColor = $sBorderColor;
|
||||
}
|
||||
|
||||
function setSolidBorder ($bSolidBorder = true)
|
||||
{
|
||||
function setSolidBorder($bSolidBorder = true) {
|
||||
$this->_bSolidBorder = (bool) $bSolidBorder;
|
||||
}
|
||||
|
||||
function setCell ($sRow, $sCell, $sContent)
|
||||
{
|
||||
function setCell($sRow, $sCell, $sContent) {
|
||||
$this->_aCells[$sRow][$sCell] = $sContent;
|
||||
$this->_aCellAlignment[$sRow][$sCell] = "";
|
||||
}
|
||||
|
||||
function setCellAlignment ($sRow, $sCell, $sAlignment)
|
||||
{
|
||||
function setCellAlignment($sRow, $sCell, $sAlignment) {
|
||||
$this->_aCellAlignment[$sRow][$sCell] = $sAlignment;
|
||||
}
|
||||
|
||||
function setCellVAlignment ($sRow, $sCell, $sAlignment)
|
||||
{
|
||||
function setCellVAlignment($sRow, $sCell, $sAlignment) {
|
||||
$this->_aCellVAlignment[$sRow][$sCell] = $sAlignment;
|
||||
}
|
||||
|
||||
function setCellColspan ($sRow, $sCell, $iColSpan)
|
||||
{
|
||||
function setCellColspan($sRow, $sCell, $iColSpan) {
|
||||
$this->_aCellColSpan[$sRow][$sCell] = $iColSpan;
|
||||
}
|
||||
|
||||
function setCellClass ($sRow, $sCell, $sClass)
|
||||
{
|
||||
function setCellClass($sRow, $sCell, $sClass) {
|
||||
$this->_aCellClass[$sRow][$sCell] = $sClass;
|
||||
}
|
||||
|
||||
function setRowBgColor ($sRow, $sColor)
|
||||
{
|
||||
function setRowBgColor($sRow, $sColor) {
|
||||
$this->_aRowBgColor[$sRow] = $sColor;
|
||||
}
|
||||
|
||||
function setRowExtra ($sRow, $sExtra)
|
||||
{
|
||||
function setRowExtra($sRow, $sExtra) {
|
||||
$this->_aRowExtra[$sRow] = $sExtra;
|
||||
}
|
||||
|
||||
function _addMultiSelJS()
|
||||
{
|
||||
function _addMultiSelJS() {
|
||||
// Trick: To save multiple selections in <select>-Element, add some JS which saves the
|
||||
// selection, comma separated in a hidden input field on change.
|
||||
|
||||
// Try ... catch prevents error messages, if function is added more than once
|
||||
// if (!fncUpdateSel) in JS has not worked...
|
||||
|
||||
|
@ -456,8 +417,7 @@ class UI_Config_Table
|
|||
return $sSkript;
|
||||
}
|
||||
|
||||
function render($bPrint = false)
|
||||
{
|
||||
function render($bPrint = false) {
|
||||
$oTable = new Template;
|
||||
$oTable->reset();
|
||||
|
||||
|
@ -469,24 +429,19 @@ class UI_Config_Table
|
|||
$bDark = false;
|
||||
$sBgColor = "";
|
||||
$bMultiSelJSAdded = false;
|
||||
if (is_array($this->_aCells))
|
||||
{
|
||||
foreach ($this->_aCells as $sRow => $aCells)
|
||||
{
|
||||
if (is_array($this->_aCells)) {
|
||||
foreach ($this->_aCells as $sRow => $aCells) {
|
||||
$iColCount++;
|
||||
//$bDark = !$bDark;
|
||||
$sLine = "";
|
||||
$iCount = 0;
|
||||
|
||||
foreach ($aCells as $sCell => $sData)
|
||||
{
|
||||
foreach ($aCells as $sCell => $sData) {
|
||||
$iCount++;
|
||||
$sTplCell = $this->_sTplCellCode;
|
||||
|
||||
if ($this->_bSolidBorder)
|
||||
{
|
||||
if ($iCount < count($aCells))
|
||||
{
|
||||
if ($this->_bSolidBorder) {
|
||||
if ($iCount < count($aCells)) {
|
||||
if ($iColCount < count($this->_aCells)) {
|
||||
$sTplCell = str_replace('{EXTRA}', 'border: 0px; border-right: 1px; border-bottom: 1px; border-color: ' . $this->_sBorderColor . '; border-style: solid;', $sTplCell);
|
||||
} else {
|
||||
|
@ -569,5 +524,7 @@ class UI_Config_Table
|
|||
return $sRendered;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
?>
|
|
@ -1,10 +1,8 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* defines.php
|
||||
*
|
||||
* define needed var for conlite setup
|
||||
*
|
||||
*
|
||||
* @package ConLite
|
||||
* @subpackage Setup
|
||||
* @license https://www.gnu.de/documents/gpl-3.0.de.html GNU General Public License (GPL)
|
||||
|
@ -33,6 +31,6 @@ define('C_SETUP_STEPFILE', 'images/steps/s%d.png');
|
|||
define('C_SETUP_STEPFILE_ACTIVE', 'images/steps/s%da.png');
|
||||
define('C_SETUP_STEPWIDTH', 28);
|
||||
define('C_SETUP_STEPHEIGHT', 28);
|
||||
define('C_SETUP_MIN_PHP_VERSION', '7.0.0');
|
||||
define('C_SETUP_MAX_PHP_VERSION', '8.0.0');
|
||||
define('C_SETUP_VERSION', '2.1.2');
|
||||
define('C_SETUP_MIN_PHP_VERSION', '7.2');
|
||||
define('C_SETUP_MAX_PHP_VERSION', '7.4');
|
||||
define('C_SETUP_VERSION', '2.2.0');
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* startup.php
|
||||
*
|
||||
|
@ -15,6 +16,7 @@ if (!defined('CON_FRAMEWORK')) {
|
|||
die('Illegal call');
|
||||
}
|
||||
define('CON_BE_PATH', '../conlite/');
|
||||
require_once 'defines.php';
|
||||
|
||||
require_once dirname(__FILE__).'/defines.php';
|
||||
|
||||
|
@ -28,13 +30,13 @@ header('Content-Type: text/html; charset=UTF-8');
|
|||
|
||||
// Check php version
|
||||
if (version_compare(PHP_VERSION, C_SETUP_MIN_PHP_VERSION, '<')) {
|
||||
die("You need PHP >= 7.0.0 to install ConLite 2.1. Sorry, even the setup doesn't work otherwise. Your version: " . PHP_VERSION . "\n");
|
||||
die("You need PHP >= " . C_SETUP_MIN_PHP_VERSION . " to install ConLite " . C_SETUP_VERSION . ". Sorry, even the setup doesn't work otherwise. Your version: " . PHP_VERSION . "\n");
|
||||
}
|
||||
|
||||
// Check version
|
||||
//PHP >= 7.0.0 and < 7.4
|
||||
if (version_compare(PHP_VERSION, C_SETUP_MAX_PHP_VERSION, '>=')) {
|
||||
die("You need PHP >= 7.0 and < 7.4 to install ConLite 2.1. Sorry, even the setup doesn't work otherwise. Your version: " . PHP_VERSION . "\n");
|
||||
$iVersionMax = substr(C_SETUP_MAX_PHP_VERSION, 0, strrpos(C_SETUP_MAX_PHP_VERSION, ".") + 1) . (1 + substr(C_SETUP_MAX_PHP_VERSION, strrpos(C_SETUP_MAX_PHP_VERSION, ".") + 1));
|
||||
|
||||
if (!(version_compare($iVersionMax, PHP_VERSION, ">") && version_compare(C_SETUP_MAX_PHP_VERSION, PHP_VERSION, "<="))) {
|
||||
die("You need PHP >= " . C_SETUP_MIN_PHP_VERSION . " and <= " . C_SETUP_MAX_PHP_VERSION . " to install ConLite " . C_SETUP_VERSION . ". Sorry, even the setup doesn't work otherwise. Your version: " . PHP_VERSION . "\n");
|
||||
}
|
||||
|
||||
|
||||
|
@ -44,7 +46,7 @@ if (version_compare(PHP_VERSION, C_SETUP_MAX_PHP_VERSION, '>=')) {
|
|||
* If you want to set a different enviroment value please define it in your .htaccess file
|
||||
* or in the server configuration.
|
||||
*
|
||||
* SetEnv CONTENIDO_ENVIRONMENT development
|
||||
* SetEnv CONLITE_ENVIRONMENT development
|
||||
*/
|
||||
if (!defined('CL_ENVIRONMENT')) {
|
||||
if (getenv('CONLITE_ENVIRONMENT')) {
|
||||
|
@ -88,6 +90,10 @@ $cfg['path']['frontend'] = CON_FRONTEND_PATH;
|
|||
$cfg['path']['conlite'] = $cfg['path']['frontend'] . '/conlite/';
|
||||
$cfg['path']['conlite_config'] = CON_FRONTEND_PATH . '/data/config/' . CL_ENVIRONMENT . '/';
|
||||
|
||||
if(!is_dir($cfg['path']['conlite_config'])) {
|
||||
die("Setup cannot find the config folder \"".$cfg['path']['conlite_config']."\"! Make shure folder exists and is readable.");
|
||||
}
|
||||
|
||||
// (bool) Flag to use native i18n.
|
||||
// Note: Enabling this could create unwanted side effects, because of
|
||||
// native gettext() behavior.
|
||||
|
@ -96,7 +102,7 @@ $cfg['native_i18n'] = false;
|
|||
session_start();
|
||||
|
||||
// includes
|
||||
//checkAndInclude('lib/defines.php');
|
||||
checkAndInclude('lib/defines.php');
|
||||
checkAndInclude($cfg['path']['frontend'] . '/pear/HTML/Common2.php');
|
||||
checkAndInclude($cfg['path']['conlite'] . 'classes/cHTML5/class.chtml.php');
|
||||
checkAndInclude($cfg['path']['conlite'] . 'classes/class.htmlelements.php');
|
||||
|
|
Laden…
In neuem Issue referenzieren