diff --git a/_archive/class/AddFiles.php b/_archive/class/AddFiles.php index b471fdeb..45ad3c2d 100644 --- a/_archive/class/AddFiles.php +++ b/_archive/class/AddFiles.php @@ -15,7 +15,7 @@ */ /** - * morefiles class. + * AddFiles class. * * @copyright The XOOPS Project http:sourceforge.net/projects/xoops/ * @license GNU GPL 2 (http:www.gnu.org/licenses/old-licenses/gpl-2.0.html) @@ -28,7 +28,7 @@ //include __DIR__.'/autoload.php'; /** - * Class MoreFiles. + * Class AddFiles. */ class AddFiles extends \XoopsObject { @@ -90,7 +90,7 @@ public static function getInstance() } /** - * @public function getFormMoreFiles + * @public function getFormMorefiles * @param mixed $action * * @return \XoopsThemeForm @@ -109,7 +109,7 @@ public function getFormAddFiles($action = false) $form = new \XoopsThemeForm($title, 'addfilesform', $action, 'post', true); $form->setExtra('enctype="multipart/form-data"'); - $modules = $this->helper->getHandler('modules')->getObjects(null); + $modules = $this->helper->getHandler('Modules')->getObjects(null); $modulesSelect = new \XoopsFormSelect(_AM_MODULEBUILDER_ADDFILES_MODULES, 'file_mid', $this->getVar('file_mid')); $modulesSelect->addOption('', _AM_MODULEBUILDER_ADDFILES_MODULE_SELECT); foreach ($modules as $mod) { @@ -147,7 +147,7 @@ public function getAddFilesValues($keys = null, $format = null, $maxDepth = null $ret = $this->getValues($keys, $format, $maxDepth); // Values $ret['id'] = $this->getVar('file_id'); - $ret['mid'] = $this->helper->getHandler('modules')->get($this->getVar('file_mid'))->getVar('mod_name'); + $ret['mid'] = $this->helper->getHandler('Modules')->get($this->getVar('file_mid'))->getVar('mod_name'); $ret['name'] = $this->getVar('file_name'); $ret['extension'] = $this->getVar('file_extension'); $ret['infolder'] = $this->getVar('file_infolder'); diff --git a/_archive/class/AddFilesHandler.php b/_archive/class/AddFilesHandler.php index 01b8f9e4..c7649d5e 100644 --- a/_archive/class/AddFilesHandler.php +++ b/_archive/class/AddFilesHandler.php @@ -13,7 +13,7 @@ */ /** - * morefiles class. + * AddFilesHandler class. * * @copyright The XOOPS Project http:sourceforge.net/projects/xoops/ * @license GNU GPL 2 (http:www.gnu.org/licenses/old-licenses/gpl-2.0.html) @@ -26,7 +26,7 @@ //include __DIR__.'/autoload.php'; /** - * Class MoreFilesHandler. + * Class AddFilesHandler. */ class AddFilesHandler extends \XoopsPersistableObjectHandler { diff --git a/_archive/class/Files/User/UserObjects.php b/_archive/class/Files/User/UserObjects.php index b391173f..82c6c592 100644 --- a/_archive/class/Files/User/UserObjects.php +++ b/_archive/class/Files/User/UserObjects.php @@ -166,7 +166,7 @@ public function getUrlFileSetVar($moduleDirname, $tableName, $fieldName) \${$tableName}Obj->setVar('{$fieldName}', formatUrl(\$_REQUEST['{$fieldName}']));\n // Set Var {$fieldName} include_once XOOPS_ROOT_PATH.'/class/uploader.php'; - \$uploaddir = {$stuModuleDirname}_UPLOAD_PATH.'/files/{$tableName}'; + \$uploaddir = {$stuModuleDirname}_UPLOAD_PATH.'/Files/{$tableName}'; \$uploader = new \XoopsMediaUploader(\$uploaddir, \$helper->getConfig('mimetypes_file'), \$helper->getConfig('maxsize_file'), null, null); if (\$uploader->fetchMedia(\$_POST['xoops_upload_file'][])) { @@ -264,7 +264,7 @@ public function getUploadFileSetVar($moduleDirname, $tableName, $fieldName) $ret = <<getConfig('mimetypes_file'), \$helper->getConfig('maxsize_file'), null, null); if (\$uploader->fetchMedia(\$_POST['xoops_upload_file'][])) { diff --git a/admin/building.php b/admin/building.php index 7619248a..a0b60455 100644 --- a/admin/building.php +++ b/admin/building.php @@ -62,7 +62,7 @@ } } // Structure - // include_once TDMC_CLASS_PATH . '/files/Architecture.php'; + // include_once TDMC_CLASS_PATH . '/Files/Architecture.php'; $handler = Modulebuilder\Files\CreateArchitecture::getInstance(); // Creation of the structure of folders and files $baseArchitecture = $handler->setBaseFoldersFiles($moduleObj); diff --git a/admin/index.php b/admin/index.php index 740ce505..6a8f4bf0 100644 --- a/admin/index.php +++ b/admin/index.php @@ -21,6 +21,9 @@ * @author Txmod Xoops http://www.txmodxoops.org * */ + +use XoopsModules\Modulebuilder\Common; + $GLOBALS['xoopsOption']['template_main'] = 'modulebuilder_index.tpl'; include __DIR__ . '/header.php'; @@ -47,11 +50,25 @@ ]; // Uploads Folders Created +//foreach (array_keys($folder) as $i) { +// $utility::createFolder($folder[$i]); +// $adminObject->addConfigBoxLine($folder[$i], 'folder'); +// $adminObject->addConfigBoxLine([$folder[$i], '777'], 'chmod'); +//} + +//------ check Upload Folders --------------- + +$adminObject->addConfigBoxLine(''); +$redirectFile = $_SERVER['SCRIPT_NAME']; + foreach (array_keys($folder) as $i) { - $adminObject->addConfigBoxLine($folder[$i], 'folder'); - $adminObject->addConfigBoxLine([$folder[$i], '777'], 'chmod'); + $adminObject->addConfigBoxLine(Common\DirectoryChecker::getDirectoryStatus($folder[$i], 0777, $redirectFile)); } +//foreach ($pathArray as $path) { +// $adminObject->addConfigBoxLine(DirectoryChecker::getDirectoryStatus($path['dir'], $path['perm'], $languageConstants, $path['action'])); +//} + $adminObject->displayNavigation(basename(__FILE__)); diff --git a/admin/morefiles.php b/admin/morefiles.php index 56712ada..4c9a35b5 100644 --- a/admin/morefiles.php +++ b/admin/morefiles.php @@ -50,12 +50,12 @@ if (0 == $modulesCount) { redirect_header('modules.php?op=new', 2, _AM_MODULEBUILDER_NOTMODULES); } - $morefilesCount = $helper->getHandler('Morefiles')->getCountMoreFiles(); - $morefilesAll = $helper->getHandler('Morefiles')->getAllMoreFiles($start, $limit); + $morefilesCount = $helper->getHandler('Morefiles')->getCountMorefiles(); + $morefilesAll = $helper->getHandler('Morefiles')->getAllMorefiles($start, $limit); // Display morefiles list if ($morefilesCount > 0) { foreach (array_keys($morefilesAll) as $i) { - $files = $morefilesAll[$i]->getValuesMoreFiles(); + $files = $morefilesAll[$i]->getValuesMorefiles(); $GLOBALS['xoopsTpl']->append('files_list', $files); unset($files); } @@ -75,7 +75,7 @@ $GLOBALS['xoopsTpl']->assign('buttons', $adminObject->displayButton('left')); $morefilesObj = $helper->getHandler('Morefiles')->create(); - $form = $morefilesObj->getFormMoreFiles(); + $form = $morefilesObj->getFormMorefiles(); $GLOBALS['xoopsTpl']->assign('form', $form->render()); break; case 'save': @@ -106,7 +106,7 @@ } $GLOBALS['xoopsTpl']->assign('error', $morefilesObj->getHtmlErrors()); - $form = $morefilesObj->getFormMoreFiles(); + $form = $morefilesObj->getFormMorefiles(); $GLOBALS['xoopsTpl']->assign('form', $form->render()); break; case 'edit': @@ -119,7 +119,7 @@ $GLOBALS['xoopsTpl']->assign('buttons', $adminObject->displayButton('left')); $morefilesObj = $helper->getHandler('Morefiles')->get($fileId); - $form = $morefilesObj->getFormMoreFiles(); + $form = $morefilesObj->getFormMorefiles(); $GLOBALS['xoopsTpl']->assign('form', $form->render()); break; case 'delete': diff --git a/admin/tables.php b/admin/tables.php index 82518f6d..45b1a469 100644 --- a/admin/tables.php +++ b/admin/tables.php @@ -246,7 +246,7 @@ } if ($helper->getHandler('Tables')->delete($tablesObj)) { // Delete items in table fieldelements - idea by goffy - $fieldelements = $helper->getHandler('Fieldelements')->getAllFieldElementsByModuleAndTableId($tableMid, $tableId); + $fieldelements = $helper->getHandler('Fieldelements')->getAllFieldelementsByModuleAndTableId($tableMid, $tableId); foreach (array_keys($fieldelements) as $fe) { $fieldElementsObj = $helper->getHandler('Fieldelements')->get($fieldelements[$fe]->getVar('fieldelement_id')); if (!$helper->getHandler('Fieldelements')->delete($fieldElementsObj)) { diff --git a/class/Building.php b/class/Building.php index 1803b6e9..64247d51 100644 --- a/class/Building.php +++ b/class/Building.php @@ -62,7 +62,7 @@ public function getForm($action = false) xoops_load('XoopsFormLoader'); $form = new \XoopsThemeForm(_AM_MODULEBUILDER_ADMIN_CONST, 'buildform', $action, 'post', true); $form->setExtra('enctype="multipart/form-data"'); - $moduleObj = $helper->getHandler('modules')->getObjects(null); + $moduleObj = $helper->getHandler('Modules')->getObjects(null); $mod_select = new \XoopsFormSelect(_AM_MODULEBUILDER_CONST_MODULES, 'mod_id', 'mod_id'); $mod_select->addOption('', _AM_MODULEBUILDER_BUILD_MODSELOPT); foreach ($moduleObj as $mod) { diff --git a/class/Common/DirectoryChecker.php b/class/Common/DirectoryChecker.php new file mode 100644 index 00000000..6e46c1af --- /dev/null +++ b/class/Common/DirectoryChecker.php @@ -0,0 +1,161 @@ +"; + $path_status .= "$path (" . constant('CO_' . $moduleDirNameUpper . '_' . 'DC_NOTAVAILABLE') . ') '; + $path_status .= "
"; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= "'; + $path_status .= '
'; + } elseif (@is_writable($path)) { + $path_status = ""; + $path_status .= "$path (" . constant('CO_' . $moduleDirNameUpper . '_' . 'DC_AVAILABLE') . ') '; + $currentMode = mb_substr(decoct(fileperms($path)), 2); + if ($currentMode != decoct($mode)) { + $path_status = ""; + $path_status .= $path . sprintf(constant('CO_' . $moduleDirNameUpper . '_' . 'DC_NOTWRITABLE'), decoct($mode), $currentMode); + $path_status .= "
"; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= "'; + $path_status .= '
'; + } + } else { + $currentMode = mb_substr(decoct(fileperms($path)), 2); + $path_status = ""; + $path_status .= $path . sprintf(constant('CO_' . $moduleDirNameUpper . '_' . 'DC_NOTWRITABLE'), decoct($mode), $currentMode); + $path_status .= "
"; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= "'; + $path_status .= '
'; + } + + return $path_status; + } + + /** + * @param $target + * @param int $mode + * + * @return bool + */ + public static function createDirectory($target, $mode = 0777) + { + $target = str_replace('..', '', $target); + + // http://www.php.net/manual/en/function.mkdir.php + return is_dir($target) || (self::createDirectory(dirname($target), $mode) && !mkdir($target, $mode) && !is_dir($target)); + } + + /** + * @param $target + * @param int $mode + * + * @return bool + */ + public static function setDirectoryPermissions($target, $mode = 0777) + { + $target = str_replace('..', '', $target); + + return @chmod($target, (int)$mode); + } + + /** + * @param $dir_path + * + * @return bool + */ + public static function dirExists($dir_path) + { + return is_dir($dir_path); + } +} + +$op = Request::getString('op', '', 'POST'); +switch ($op) { + case 'createdir': + if (\Xmf\Request::hasVar('path', 'POST')) { + $path = $_POST['path']; + } + if (\Xmf\Request::hasVar('redirect', 'POST')) { + $redirect = $_POST['redirect']; + } + $msg = DirectoryChecker::createDirectory($path) ? constant('CO_' . $moduleDirNameUpper . '_' . 'DC_DIRCREATED') : constant('CO_' . $moduleDirNameUpper . '_' . 'DC_DIRNOTCREATED'); + redirect_header($redirect, 2, $msg . ': ' . $path); + break; + case 'setdirperm': + if (\Xmf\Request::hasVar('path', 'POST')) { + $path = $_POST['path']; + } + if (\Xmf\Request::hasVar('redirect', 'POST')) { + $redirect = $_POST['redirect']; + } + if (\Xmf\Request::hasVar('mode', 'POST')) { + $mode = $_POST['mode']; + } + $msg = DirectoryChecker::setDirectoryPermissions($path, $mode) ? constant('CO_' . $moduleDirNameUpper . '_' . 'DC_PERMSET') : constant('CO_' . $moduleDirNameUpper . '_' . 'DC_PERMNOTSET'); + redirect_header($redirect, 2, $msg . ': ' . $path); + break; +} diff --git a/class/Common/FileChecker.php b/class/Common/FileChecker.php new file mode 100644 index 00000000..badd4200 --- /dev/null +++ b/class/Common/FileChecker.php @@ -0,0 +1,161 @@ +"; + $path_status .= "$file_path (" . constant('CO_' . $moduleDirNameUpper . '_' . 'FC_AVAILABLE') . ') '; + } else { + $path_status = ""; + $path_status .= "$file_path (" . constant('CO_' . $moduleDirNameUpper . '_' . 'FC_NOTAVAILABLE') . ') '; + } + } else { + if (self::compareFiles($file_path, $original_file_path)) { + $path_status = ""; + $path_status .= "$file_path (" . constant('CO_' . $moduleDirNameUpper . '_' . 'FC_AVAILABLE') . ') '; + } else { + $path_status = ""; + $path_status .= "$file_path (" . constant('CO_' . $moduleDirNameUpper . '_' . 'FC_NOTAVAILABLE') . ') '; + $path_status .= "
"; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= ""; + $path_status .= "'; + $path_status .= '
'; + } + } + + return $path_status; + } + + /** + * @param $source_path + * @param $destination_path + * + * @return bool + */ + public static function copyFile($source_path, $destination_path) + { + $source_path = str_replace('..', '', $source_path); + $destination_path = str_replace('..', '', $destination_path); + + return @copy($source_path, $destination_path); + } + + /** + * @param $file1_path + * @param $file2_path + * + * @return bool + */ + public static function compareFiles($file1_path, $file2_path) + { + if (!self::fileExists($file1_path) || !self::fileExists($file2_path)) { + return false; + } + if (filetype($file1_path) !== filetype($file2_path)) { + return false; + } + if (filesize($file1_path) !== filesize($file2_path)) { + return false; + } + $crc1 = mb_strtoupper(dechex(crc32(file_get_contents($file1_path)))); + $crc2 = mb_strtoupper(dechex(crc32(file_get_contents($file2_path)))); + + return !($crc1 !== $crc2); + } + + /** + * @param $file_path + * + * @return bool + */ + public static function fileExists($file_path) + { + return is_file($file_path); + } + + /** + * @param $target + * @param int $mode + * + * @return bool + */ + public static function setFilePermissions($target, $mode = 0777) + { + $target = str_replace('..', '', $target); + + return @chmod($target, (int)$mode); + } +} + +$op = Request::getString('op', '', 'POST'); +switch ($op) { + case 'copyfile': + if (\Xmf\Request::hasVar('original_file_path', 'POST')) { + $original_file_path = $_POST['original_file_path']; + } + if (\Xmf\Request::hasVar('file_path', 'POST')) { + $file_path = $_POST['file_path']; + } + if (\Xmf\Request::hasVar('redirect', 'POST')) { + $redirect = $_POST['redirect']; + } + $msg = FileChecker::copyFile($original_file_path, $file_path) ? constant('CO_' . $moduleDirNameUpper . '_' . 'FC_FILECOPIED') : constant('CO_' . $moduleDirNameUpper . '_' . 'FC_FILENOTCOPIED'); + redirect_header($redirect, 2, $msg . ': ' . $file_path); + break; +} diff --git a/class/Common/SysUtility.php b/class/Common/SysUtility.php new file mode 100644 index 00000000..bc589048 --- /dev/null +++ b/class/Common/SysUtility.php @@ -0,0 +1,214 @@ + + * @author Mamba + */ + +use MyTextSanitizer; +use XoopsFormDhtmlTextArea; +use XoopsFormTextArea; +use XoopsModules\Modulebuilder; +use XoopsModules\Modulebuilder\Helper; + +/** + * Class Utility + */ +class SysUtility +{ + use VersionChecks; //checkVerXoops, checkVerPhp Traits + use ServerStats; // getServerStats Trait + use FilesManagement; // Files Management Trait + + + /** + * Access the only instance of this class + * + * @return object + * + */ + public static function getInstance() + { + static $instance; + if (null === $instance) { + $instance = new static(); + } + + return $instance; + } + + /** + * truncateHtml can truncate a string up to a number of characters while preserving whole words and HTML tags + * www.gsdesign.ro/blog/cut-html-string-without-breaking-the-tags + * www.cakephp.org + * + * @param string $text String to truncate. + * @param int $length Length of returned string, including ellipsis. + * @param string $ending Ending to be appended to the trimmed string. + * @param bool $exact If false, $text will not be cut mid-word + * @param bool $considerHtml If true, HTML tags would be handled correctly + * + * @return string Trimmed string. + */ + public static function truncateHtml($text, $length = 100, $ending = '...', $exact = false, $considerHtml = true) + { + if ($considerHtml) { + // if the plain text is shorter than the maximum length, return the whole text + if (mb_strlen(preg_replace('/<.*?' . '>/', '', $text)) <= $length) { + return $text; + } + // splits all html-tags to scanable lines + preg_match_all('/(<.+?' . '>)?([^<>]*)/s', $text, $lines, PREG_SET_ORDER); + $total_length = mb_strlen($ending); + $open_tags = []; + $truncate = ''; + foreach ($lines as $line_matchings) { + // if there is any html-tag in this line, handle it and add it (uncounted) to the output + if (!empty($line_matchings[1])) { + // if it's an "empty element" with or without xhtml-conform closing slash + if (preg_match('/^<(\s*.+?\/\s*|\s*(img|br|input|hr|area|base|basefont|col|frame|isindex|link|meta|param)(\s.+?)?)>$/is', $line_matchings[1])) { + // do nothing + // if tag is a closing tag + } elseif (preg_match('/^<\s*\/([^\s]+?)\s*>$/s', $line_matchings[1], $tag_matchings)) { + // delete tag from $open_tags list + $pos = array_search($tag_matchings[1], $open_tags, true); + if (false !== $pos) { + unset($open_tags[$pos]); + } + // if tag is an opening tag + } elseif (preg_match('/^<\s*([^\s>!]+).*?' . '>$/s', $line_matchings[1], $tag_matchings)) { + // add tag to the beginning of $open_tags list + array_unshift($open_tags, mb_strtolower($tag_matchings[1])); + } + // add html-tag to $truncate'd text + $truncate .= $line_matchings[1]; + } + // calculate the length of the plain text part of the line; handle entities as one character + $content_length = mb_strlen(preg_replace('/&[0-9a-z]{2,8};|&#[0-9]{1,7};|[0-9a-f]{1,6};/i', ' ', $line_matchings[2])); + if ($total_length + $content_length > $length) { + // the number of characters which are left + $left = $length - $total_length; + $entities_length = 0; + // search for html entities + if (preg_match_all('/&[0-9a-z]{2,8};|&#[0-9]{1,7};|[0-9a-f]{1,6};/i', $line_matchings[2], $entities, PREG_OFFSET_CAPTURE)) { + // calculate the real length of all entities in the legal range + foreach ($entities[0] as $entity) { + if ($left >= $entity[1] + 1 - $entities_length) { + $left--; + $entities_length += mb_strlen($entity[0]); + } else { + // no more characters left + break; + } + } + } + $truncate .= mb_substr($line_matchings[2], 0, $left + $entities_length); + // maximum lenght is reached, so get off the loop + break; + } + $truncate .= $line_matchings[2]; + $total_length += $content_length; + + // if the maximum length is reached, get off the loop + if ($total_length >= $length) { + break; + } + } + } else { + if (mb_strlen($text) <= $length) { + return $text; + } + $truncate = mb_substr($text, 0, $length - mb_strlen($ending)); + } + // if the words shouldn't be cut in the middle... + if (!$exact) { + // ...search the last occurance of a space... + $spacepos = mb_strrpos($truncate, ' '); + if (isset($spacepos)) { + // ...and cut the text in this position + $truncate = mb_substr($truncate, 0, $spacepos); + } + } + // add the defined ending to the text + $truncate .= $ending; + if ($considerHtml) { + // close all unclosed html-tags + foreach ($open_tags as $tag) { + $truncate .= ''; + } + } + + return $truncate; + } + + /** + * @param \Xmf\Module\Helper $helper + * @param array|null $options + * @return \XoopsFormDhtmlTextArea|\XoopsFormEditor + */ + public static function getEditor($helper = null, $options = null) + { + /** @var Helper $helper */ + if (null === $options) { + $options = []; + $options['name'] = 'Editor'; + $options['value'] = 'Editor'; + $options['rows'] = 10; + $options['cols'] = '100%'; + $options['width'] = '100%'; + $options['height'] = '400px'; + } + + if (null === $helper) { + $helper = Helper::getInstance(); + } + + $isAdmin = $helper->isUserAdmin(); + + if (class_exists('XoopsFormEditor')) { + if ($isAdmin) { + $descEditor = new \XoopsFormEditor(ucfirst($options['name']), $helper->getConfig('editorAdmin'), $options, $nohtml = false, $onfailure = 'textarea'); + } else { + $descEditor = new \XoopsFormEditor(ucfirst($options['name']), $helper->getConfig('editorUser'), $options, $nohtml = false, $onfailure = 'textarea'); + } + } else { + $descEditor = new \XoopsFormDhtmlTextArea(ucfirst($options['name']), $options['name'], $options['value'], '100%', '100%'); + } + + // $form->addElement($descEditor); + + return $descEditor; + } + + /** + * @param $fieldname + * @param $table + * + * @return bool + */ + function fieldExists($fieldname, $table) + { + global $xoopsDB; + $result = $xoopsDB->queryF("SHOW COLUMNS FROM $table LIKE '$fieldname'"); + + return ($xoopsDB->getRowsNum($result) > 0); + } +} diff --git a/class/FieldElements.php b/class/Fieldelements.php similarity index 94% rename from class/FieldElements.php rename to class/Fieldelements.php index c7bf8b16..8d865183 100644 --- a/class/FieldElements.php +++ b/class/Fieldelements.php @@ -26,9 +26,9 @@ */ /** - * Class FieldElements. + * Class Fieldelements. */ -class FieldElements extends \XoopsObject +class Fieldelements extends \XoopsObject { /** * @public function constructor class @@ -62,7 +62,7 @@ public function __call($method, $args) /** * @static function getInstance * @param null - * @return FieldElements + * @return Fieldelements */ public static function getInstance() { @@ -81,7 +81,7 @@ public static function getInstance() * @param null $maxDepth * @return array */ - public function getValuesFieldElements($keys = null, $format = null, $maxDepth = null) + public function getValuesFieldelements($keys = null, $format = null, $maxDepth = null) { $ret = $this->getValues($keys, $format, $maxDepth); // Values diff --git a/class/FieldElementsHandler.php b/class/FieldelementsHandler.php similarity index 81% rename from class/FieldElementsHandler.php rename to class/FieldelementsHandler.php index 2fd8c461..80d07ca4 100644 --- a/class/FieldElementsHandler.php +++ b/class/FieldelementsHandler.php @@ -26,9 +26,9 @@ */ /** - * Class FieldElementsHandler. + * Class FieldelementsHandler. */ -class FieldElementsHandler extends \XoopsPersistableObjectHandler +class FieldelementsHandler extends \XoopsPersistableObjectHandler { /** * @public function constructor class @@ -36,7 +36,7 @@ class FieldElementsHandler extends \XoopsPersistableObjectHandler */ public function __construct(\XoopsDatabase $db) { - parent::__construct($db, 'modulebuilder_fieldelements', FieldElements::class, 'fieldelement_id', 'fieldelement_name'); + parent::__construct($db, 'modulebuilder_fieldelements', Fieldelements::class, 'fieldelement_id', 'fieldelement_name'); } /** @@ -47,10 +47,10 @@ public function __construct(\XoopsDatabase $db) * @param string $order * @return int */ - public function getCountFieldElements($start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') + public function getCountFieldelements($start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') { $crCountFieldElems = new \CriteriaCompo(); - $crCountFieldElems = $this->getFieldElementsCriteria($crCountFieldElems, $start, $limit, $sort, $order); + $crCountFieldElems = $this->getFieldelementsCriteria($crCountFieldElems, $start, $limit, $sort, $order); return parent::getCount($crCountFieldElems); } @@ -63,10 +63,10 @@ public function getCountFieldElements($start = 0, $limit = 0, $sort = 'fieldelem * @param string $order * @return array */ - public function getObjectsFieldElements($start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') + public function getObjectsFieldelements($start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') { $crObjectsFieldElems = new \CriteriaCompo(); - $crObjectsFieldElems = $this->getFieldElementsCriteria($crObjectsFieldElems, $start, $limit, $sort, $order); + $crObjectsFieldElems = $this->getFieldelementsCriteria($crObjectsFieldElems, $start, $limit, $sort, $order); return $this->getObjects($crObjectsFieldElems); } @@ -79,10 +79,10 @@ public function getObjectsFieldElements($start = 0, $limit = 0, $sort = 'fieldel * @param string $order * @return array */ - public function getAllFieldElements($start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') + public function getAllFieldelements($start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') { $crAllFieldElems = new \CriteriaCompo(); - $crAllFieldElems = $this->getFieldElementsCriteria($crAllFieldElems, $start, $limit, $sort, $order); + $crAllFieldElems = $this->getFieldelementsCriteria($crAllFieldElems, $start, $limit, $sort, $order); return $this->getAll($crAllFieldElems); } @@ -97,18 +97,18 @@ public function getAllFieldElements($start = 0, $limit = 0, $sort = 'fieldelemen * @param string $order * @return array */ - public function getAllFieldElementsByModuleAndTableId($modId, $tabId, $start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') + public function getAllFieldelementsByModuleAndTableId($modId, $tabId, $start = 0, $limit = 0, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') { $crAllFieldElemsByModule = new \CriteriaCompo(); $crAllFieldElemsByModule->add(new \Criteria('fieldelement_mid', $modId)); $crAllFieldElemsByModule->add(new \Criteria('fieldelement_tid', $tabId)); - $crAllFieldElemsByModule = $this->getFieldElementsCriteria($crAllFieldElemsByModule, $start, $limit, $sort, $order); + $crAllFieldElemsByModule = $this->getFieldelementsCriteria($crAllFieldElemsByModule, $start, $limit, $sort, $order); return $this->getAll($crAllFieldElemsByModule); } /** - * Get FieldElements Criteria. + * Get Fieldelements Criteria. * @param $crFieldElemsCriteria * @param $start * @param $limit @@ -116,7 +116,7 @@ public function getAllFieldElementsByModuleAndTableId($modId, $tabId, $start = 0 * @param $order * @return mixed */ - private function getFieldElementsCriteria($crFieldElemsCriteria, $start, $limit, $sort, $order) + private function getFieldelementsCriteria($crFieldElemsCriteria, $start, $limit, $sort, $order) { $crFieldElemsCriteria->setStart($start); $crFieldElemsCriteria->setLimit($limit); @@ -127,7 +127,7 @@ private function getFieldElementsCriteria($crFieldElemsCriteria, $start, $limit, } /** - * Get FieldElements Criteria. + * Get Fieldelements Criteria. * @param $crFieldElemsCriteria * @param $start * @param $limit @@ -135,9 +135,9 @@ private function getFieldElementsCriteria($crFieldElemsCriteria, $start, $limit, * @param $order * @return mixed */ - public function getFieldElementsList($crFieldElemsCriteria, $start = 0, $limit = 0, $sort = 'fieldelement_sort', $order = 'ASC') + public function getFieldelementsList($crFieldElemsCriteria, $start = 0, $limit = 0, $sort = 'fieldelement_sort', $order = 'ASC') { - $crFieldElems = $this->getFieldElementsCriteria($crFieldElemsCriteria, $start, $limit, $sort, $order); + $crFieldElems = $this->getFieldelementsCriteria($crFieldElemsCriteria, $start, $limit, $sort, $order); $fieldeleArr = $this->getAll($crFieldElems); $fieldele = []; foreach (array_keys($fieldeleArr) as $i) { diff --git a/class/Fields.php b/class/Fields.php index 7c467c04..91c79230 100644 --- a/class/Fields.php +++ b/class/Fields.php @@ -206,7 +206,7 @@ private function getFormNewLine($form, $class, $i, $fieldMid, $fieldTid, $fName, $crTable = new \CriteriaCompo(); $crTable->add(new \Criteria('fieldelement_mid', $fieldMid)); $fieldElementsSelect = new \XoopsFormSelect(_AM_MODULEBUILDER_FIELD_ELEMENT_NAME, 'field_element[' . $i . ']'); - $fieldElementsSelect->addOptionArray($helper->getHandler('Fieldelements')->getFieldElementsList($crElement)); + $fieldElementsSelect->addOptionArray($helper->getHandler('Fieldelements')->getFieldelementsList($crElement)); $fieldElementsSelect->addOptionArray($helper->getHandler('Fieldelements')->getList($crTable)); $fieldElementsSelect->setExtra(" onchange='presetField(". $i . ")' "); unset($crElement, $crTable); @@ -373,7 +373,7 @@ public function getFormEdit($fieldMid = null, $fieldTid = null, $action = false) $crTable = new \CriteriaCompo(); $crTable->add(new \Criteria('fieldelement_mid', $fieldMid)); $fieldElementsSelect = new \XoopsFormSelect(_AM_MODULEBUILDER_FIELD_ELEMENT_NAME, 'field_element[' . $id . ']', $field->getVar('field_element')); - $fieldElementsSelect->addOptionArray($helper->getHandler('Fieldelements')->getFieldElementsList($crElement)); + $fieldElementsSelect->addOptionArray($helper->getHandler('Fieldelements')->getFieldelementsList($crElement)); $fieldElementsSelect->addOptionArray($helper->getHandler('Fieldelements')->getList($crTable)); $fieldElementsSelect->setExtra(" onchange='presetField(". $id . ")' "); unset($crElement, $crTable); diff --git a/class/Files/Classes/ClassFiles.php b/class/Files/Classes/ClassFiles.php index cf563757..0ff763ae 100644 --- a/class/Files/Classes/ClassFiles.php +++ b/class/Files/Classes/ClassFiles.php @@ -180,7 +180,7 @@ private function getClassObject($module, $table, $fields) $fieldName = $fields[$f]->getVar('field_name'); $fieldElement = $fields[$f]->getVar('field_element'); $fieldInForm[] = $fields[$f]->getVar('field_inform'); - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementId[] = $fieldElements->getVar('fieldelement_id'); $rpFieldName = $this->getRightString($fieldName); if (in_array(5, $fieldElementId)) { @@ -430,7 +430,7 @@ private function getValuesInObject($moduleDirname, $table, $fields) $getValues .= $xc->getXcFormatTimeStamp("ret['{$rpFieldName}']", "\$this->getVar('{$fieldName}')", 'm', "\t\t"); break; default: - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementTid = $fieldElements->getVar('fieldelement_tid'); if ((int)$fieldElementTid > 0 ) { $fieldElementMid = $fieldElements->getVar('fieldelement_mid'); @@ -517,7 +517,7 @@ private function getOptionsCheck($table) $fieldName = $fields[$f]->getVar('field_name'); $fieldElement = $fields[$f]->getVar('field_element'); - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementId = $fieldElements->getVar('fieldelement_id'); $rpFieldName = $this->getRightString($fieldName); if (5 == $fieldElementId) { diff --git a/class/Files/Classes/ClassFormElements.php b/class/Files/Classes/ClassFormElements.php index de1974b7..e46fc1ac 100644 --- a/class/Files/Classes/ClassFormElements.php +++ b/class/Files/Classes/ClassFormElements.php @@ -797,7 +797,7 @@ private function getXoopsFormTable($language,$fieldName, $fieldElement, $require $t = "\t\t"; $ret = ''; - $fElement = $tc->getHandler('fieldelements')->get($fieldElement); + $fElement = $tc->getHandler('Fieldelements')->get($fieldElement); $rpFieldelementName = mb_strtolower(str_replace('Table : ', '', $fElement->getVar('fieldelement_name'))); $ret .= $pc->getPhpCodeCommentLine('Form Table', $rpFieldelementName, $t); $ccFieldName = $tf->getCamelCase($fieldName, false, true); @@ -910,7 +910,7 @@ public function renderElements() $language = $languageFunct . mb_strtoupper($tableSoleName) . '_' . mb_strtoupper($rpFieldName); $required = (1 == $fields[$f]->getVar('field_required')) ? ', true' : ''; - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementId[] = $fieldElements->getVar('fieldelement_id'); if (1 == $fieldInForm) { @@ -994,7 +994,7 @@ public function renderElements() break; } - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementTid = $fieldElements->getVar('fieldelement_tid'); if ((int)$fieldElementTid > 0 ) { if ((1 == $fieldParent) || 1 == $table->getVar('table_category')) { diff --git a/class/Files/Classes/ClassHandlerFiles.php b/class/Files/Classes/ClassHandlerFiles.php index 8cbaf52f..218d8dfa 100644 --- a/class/Files/Classes/ClassHandlerFiles.php +++ b/class/Files/Classes/ClassHandlerFiles.php @@ -233,7 +233,7 @@ private function getClassByCategory($moduleDirname, $tableName, $tableFieldName, $pc = Modulebuilder\Files\CreatePhpCode::getInstance(); $xc = Modulebuilder\Files\CreateXoopsCode::getInstance(); $ucfTableName = ucfirst($tableName); - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementName = $fieldElements->getVar('fieldelement_name'); $fieldNameDesc = ucfirst(mb_substr($fieldElementName, mb_strrpos($fieldElementName, ':'), mb_strlen($fieldElementName))); $topicTableName = str_replace(': ', '', $fieldNameDesc); @@ -354,7 +354,7 @@ public function render() } $fieldElement = $fields[$f]->getVar('field_element'); - $fieldElements = $tc->getHandler('fieldelements')->get($fieldElement); + $fieldElements = $tc->getHandler('Fieldelements')->get($fieldElement); $fieldElementId[] = $fieldElements->getVar('fieldelement_id'); } $namespace = $pc->getPhpCodeNamespace(['XoopsModules', $moduleDirname]); diff --git a/class/Files/CreateArchitecture.php b/class/Files/CreateArchitecture.php index 81b16f6a..0460c596 100644 --- a/class/Files/CreateArchitecture.php +++ b/class/Files/CreateArchitecture.php @@ -200,7 +200,7 @@ public function setFilesToBuilding($module) $moduleDirname = $module->getVar('mod_dirname'); $icon32 = 'assets/icons/32'; $tables = $tf->getTableTables($modId); - $files = $tf->getTableMoreFiles($modId); + $files = $tf->getTableMorefiles($modId); $ret = []; $templateType = 'defstyle'; @@ -355,7 +355,7 @@ public function setFilesToBuilding($module) $fileExtension = $files[$t]->getVar('file_extension'); $fileInfolder = $files[$t]->getVar('file_infolder'); // More File - $moreFiles = Modulebuilder\MoreFiles::getInstance(); + $moreFiles = Modulebuilder\Morefiles::getInstance(); $moreFiles->write($module, $fileName, $fileInfolder, $fileExtension); $ret[] = $moreFiles->render(); } diff --git a/class/Files/CreateFile.php b/class/Files/CreateFile.php index 888981fc..621319e5 100644 --- a/class/Files/CreateFile.php +++ b/class/Files/CreateFile.php @@ -495,7 +495,7 @@ public function getHeaderFilesComments($module, $noPhpFile = null, $namespace = $ret .= "\n{$namespace}/*\n"; - $filename = TDMC_CLASS_PATH . '/files/docs/license.txt'; + $filename = TDMC_CLASS_PATH . '/Files/Docs/license.txt'; $handle = fopen($filename, 'rb'); $data = fread($handle, filesize($filename)); fclose($handle); diff --git a/class/Files/CreateMoreFiles.php b/class/Files/CreateMoreFiles.php index ae38fa01..21dc2438 100644 --- a/class/Files/CreateMoreFiles.php +++ b/class/Files/CreateMoreFiles.php @@ -26,9 +26,9 @@ */ /** - * Class MoreFiles. + * Class CreateMoreFiles. */ -class MoreFiles extends Files\CreateFile +class CreateMoreFiles extends Files\CreateFile { /** * @var mixed @@ -52,7 +52,7 @@ public function __construct() /** * @static function getInstance * @param null - * @return MoreFiles + * @return CreateMorefiles */ public static function getInstance() { @@ -85,12 +85,12 @@ public function write($module, $filename, $folder, $extension) } /** - * @private function getMoreFilesPhp + * @private function getMorefilesPhp * * @param string $header * @return string */ - private function getMoreFilesPhp($header = '') + private function getMorefilesPhp($header = '') { $ret = "\n"; $ret .= "\tPlease! put your template code here\n"; @@ -114,10 +114,10 @@ private function getMoreFilesTpl() } /** - * @private function getMoreFilesHtml + * @private function getMorefilesHtml * @return string */ - private function getMoreFilesHtml() + private function getMorefilesHtml() { $ret = "
\n"; $ret .= "\tPlease! put your Html code here\n"; @@ -127,34 +127,34 @@ private function getMoreFilesHtml() } /** - * @private function getMoreFilesText + * @private function getMorefilesText * @param null * * @return string */ - private function getMoreFilesText() + private function getMorefilesText() { return "# Please! put your text code here\n"; } /** - * @private function getMoreFilesSql + * @private function getMorefilesSql * @param null * * @return string */ - private function getMoreFilesSql() + private function getMorefilesSql() { return "# Please! put your sql code here\n"; } /** - * @private function getMoreFilesCss + * @private function getMorefilesCss * @param $header * * @return string */ - private function getMoreFilesCss($header = '') + private function getMorefilesCss($header = '') { $ret = "@charset \"UTF-8\"\n"; $ret .= "{$header}\n\nPlease! put your css code here\n"; @@ -163,12 +163,12 @@ private function getMoreFilesCss($header = '') } /** - * @private function getMoreFilesDefault + * @private function getMorefilesDefault * @param null * * @return string */ - private function getMoreFilesDefault() + private function getMorefilesDefault() { return "Default File\n"; } @@ -185,25 +185,25 @@ public function render() $header = $this->getHeaderFilesComments($module, 0); switch ($this->extension) { case 'php': - $content = $this->getMoreFilesPhp($header); + $content = $this->getMorefilesPhp($header); break; case 'tpl': - $content = $this->getMoreFilesTpl(); + $content = $this->getMorefilesTpl(); break; case 'html': - $content = $this->getMoreFilesHtml(); + $content = $this->getMorefilesHtml(); break; case 'text': - $content = $this->getMoreFilesText(); + $content = $this->getMorefilesText(); break; case 'sql': - $content = $this->getMoreFilesSql(); + $content = $this->getMorefilesSql(); break; case 'css': - $content = $this->getMoreFilesCss($header); + $content = $this->getMorefilesCss($header); break; default: - $content = $this->getMoreFilesDefault(); + $content = $this->getMorefilesDefault(); break; } diff --git a/class/Files/CreateTableFields.php b/class/Files/CreateTableFields.php index ba3b8d9f..34621365 100644 --- a/class/Files/CreateTableFields.php +++ b/class/Files/CreateTableFields.php @@ -68,7 +68,7 @@ public function getTableTables($mId, $sort = 'table_id ASC, table_name', $order $criteria->add(new \Criteria('table_mid', $mId)); // $mId = module Id $criteria->setSort($sort); $criteria->setOrder($order); - $tables = Modulebuilder\Helper::getInstance()->getHandler('tables')->getObjects($criteria); + $tables = Modulebuilder\Helper::getInstance()->getHandler('Tables')->getObjects($criteria); unset($criteria); return $tables; @@ -91,14 +91,14 @@ public function getTableFields($mId, $tId, $sort = 'field_id ASC, field_name', $ $criteria->add(new \Criteria('field_tid', $tId)); // $tId = table Id $criteria->setSort($sort); $criteria->setOrder($order); - $fields = Modulebuilder\Helper::getInstance()->getHandler('fields')->getObjects($criteria); + $fields = Modulebuilder\Helper::getInstance()->getHandler('Fields')->getObjects($criteria); unset($criteria); return $fields; } /** - * @public function getTableFieldElements + * @public function getTableFieldelements * * @param $mId * @param $tId @@ -107,7 +107,7 @@ public function getTableFields($mId, $tId, $sort = 'field_id ASC, field_name', $ * @param string $order * @return mixed */ - public function getTableFieldElements($mId = null, $tId = null, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') + public function getTableFieldelements($mId = null, $tId = null, $sort = 'fieldelement_id ASC, fieldelement_name', $order = 'ASC') { $criteria = new \CriteriaCompo(); if (null != $mId) { @@ -120,14 +120,14 @@ public function getTableFieldElements($mId = null, $tId = null, $sort = 'fieldel $criteria->setSort($sort); $criteria->setOrder($order); } - $fieldElements = Modulebuilder\Helper::getInstance()->getHandler('fieldelements')->getObjects($criteria); + $fieldElements = Modulebuilder\Helper::getInstance()->getHandler('Fieldelements')->getObjects($criteria); unset($criteria); return $fieldElements; } /** - * @public function getTableMoreFiles + * @public function getTableMorefiles * * @param $mId * @@ -135,13 +135,13 @@ public function getTableFieldElements($mId = null, $tId = null, $sort = 'fieldel * @param string $order * @return mixed */ - public function getTableMoreFiles($mId, $sort = 'file_id ASC, file_name', $order = 'ASC') + public function getTableMorefiles($mId, $sort = 'file_id ASC, file_name', $order = 'ASC') { $criteria = new \CriteriaCompo(); $criteria->add(new \Criteria('file_mid', $mId)); // $mId = module Id $criteria->setSort($sort); $criteria->setOrder($order); - $morefiles = Modulebuilder\Helper::getInstance()->getHandler('morefiles')->getObjects($criteria); + $morefiles = Modulebuilder\Helper::getInstance()->getHandler('Morefiles')->getObjects($criteria); unset($criteria); return $morefiles; diff --git a/class/Files/Language/LanguageAdmin.php b/class/Files/Language/LanguageAdmin.php index 32a85020..0818c8cb 100644 --- a/class/Files/Language/LanguageAdmin.php +++ b/class/Files/Language/LanguageAdmin.php @@ -183,7 +183,7 @@ public function getLanguageAdminClass($language, $tables) $rpFieldName = $this->getRightString($fieldName); if ($fieldElement > 16) { - $fieldElements = Modulebuilder\Helper::getInstance()->getHandler('fieldelements')->get($fieldElement); + $fieldElements = Modulebuilder\Helper::getInstance()->getHandler('Fieldelements')->get($fieldElement); $fieldElementName = $fieldElements->getVar('fieldelement_name'); $fieldNameDesc = mb_substr($fieldElementName, mb_strrpos($fieldElementName, ':'), mb_strlen($fieldElementName)); $fieldNameDesc = str_replace(': ', '', $fieldNameDesc); diff --git a/class/Files/Templates/User/Defstyle/MoreFiles.php b/class/Files/Templates/User/Defstyle/MoreFiles.php index e422ebd7..1ad5952f 100644 --- a/class/Files/Templates/User/Defstyle/MoreFiles.php +++ b/class/Files/Templates/User/Defstyle/MoreFiles.php @@ -27,9 +27,9 @@ */ /** - * class MoreFiles. + * class Morefiles. */ -class MoreFiles extends Files\CreateFile +class Morefiles extends Files\CreateFile { private $folder = null; @@ -47,7 +47,7 @@ public function __construct() /** * @static function getInstance * @param null - * @return MoreFiles + * @return Morefiles */ public static function getInstance() { diff --git a/class/Helper.php b/class/Helper.php index 19b359ef..cdff5d52 100644 --- a/class/Helper.php +++ b/class/Helper.php @@ -70,8 +70,7 @@ public function getDirname() */ public function getHandler($name) { - - $class = '\\XoopsModules\\' . ucfirst(mb_strtolower(basename(dirname(__DIR__)))) . '\\' . $name . 'Handler'; + $class = __NAMESPACE__ . '\\' . ucfirst($name) . 'Handler'; if (!class_exists($class)) { throw new \RuntimeException("Class '$class' not found"); } diff --git a/class/MoreFiles.php b/class/Morefiles.php similarity index 94% rename from class/MoreFiles.php rename to class/Morefiles.php index 9904c1f1..7659255f 100644 --- a/class/MoreFiles.php +++ b/class/Morefiles.php @@ -27,14 +27,14 @@ */ //include __DIR__.'/autoload.php'; /* -* @Class MoreFiles +* @Class Morefiles * @extends \XoopsObject */ /** - * Class MoreFiles. + * Class Morefiles. */ -class MoreFiles extends \XoopsObject +class Morefiles extends \XoopsObject { /** * Settings. @@ -75,7 +75,7 @@ public function __call($method, $args) * * @param null * - * @return MoreFiles + * @return Morefiles */ public static function getInstance() { @@ -88,12 +88,12 @@ public static function getInstance() } /** - * @public function getFormMoreFiles + * @public function getFormMorefiles * * @param bool|mixed $action * @return \XoopsThemeForm */ - public function getFormMoreFiles($action = false) + public function getFormMorefiles($action = false) { $helper = Modulebuilder\Helper::getInstance(); if (false === $action) { @@ -144,7 +144,7 @@ public function getFormMoreFiles($action = false) * * @return array */ - public function getValuesMoreFiles($keys = null, $format = null, $maxDepth = null) + public function getValuesMorefiles($keys = null, $format = null, $maxDepth = null) { $helper = Modulebuilder\Helper::getInstance(); $ret = $this->getValues($keys, $format, $maxDepth); diff --git a/class/MoreFilesHandler.php b/class/MorefilesHandler.php similarity index 67% rename from class/MoreFilesHandler.php rename to class/MorefilesHandler.php index df5bd77c..b9e7b666 100644 --- a/class/MoreFilesHandler.php +++ b/class/MorefilesHandler.php @@ -26,10 +26,10 @@ //include __DIR__.'/autoload.php'; /** - * @Class MoreFilesHandler + * @Class MorefilesHandler * @extends \XoopsPersistableObjectHandler */ -class MoreFilesHandler extends \XoopsPersistableObjectHandler +class MorefilesHandler extends \XoopsPersistableObjectHandler { /** * @public function constructor class @@ -38,7 +38,7 @@ class MoreFilesHandler extends \XoopsPersistableObjectHandler */ public function __construct(\XoopsDatabase $db) { - parent::__construct($db, 'modulebuilder_morefiles', MoreFiles::class, 'file_id', 'file_name'); + parent::__construct($db, 'modulebuilder_morefiles', Morefiles::class, 'file_id', 'file_name'); } /** @@ -78,7 +78,7 @@ public function getInsertId() } /** - * Get Count MoreFiles. + * Get Count Morefiles. * * @param int $start * @param int $limit @@ -87,16 +87,16 @@ public function getInsertId() * * @return int */ - public function getCountMoreFiles($start = 0, $limit = 0, $sort = 'file_id ASC, file_name', $order = 'ASC') + public function getCountMorefiles($start = 0, $limit = 0, $sort = 'file_id ASC, file_name', $order = 'ASC') { - $crMoreFilesCount = new \CriteriaCompo(); - $crMoreFilesCount = $this->getMoreFilesCriteria($crMoreFilesCount, $start, $limit, $sort, $order); + $crMorefilesCount = new \CriteriaCompo(); + $crMorefilesCount = $this->getMorefilesCriteria($crMorefilesCount, $start, $limit, $sort, $order); - return $this->getCount($crMoreFilesCount); + return $this->getCount($crMorefilesCount); } /** - * Get All MoreFiles. + * Get All Morefiles. * * @param int $start * @param int $limit @@ -105,16 +105,16 @@ public function getCountMoreFiles($start = 0, $limit = 0, $sort = 'file_id ASC, * * @return array */ - public function getAllMoreFiles($start = 0, $limit = 0, $sort = 'file_id ASC, file_name', $order = 'ASC') + public function getAllMorefiles($start = 0, $limit = 0, $sort = 'file_id ASC, file_name', $order = 'ASC') { - $crMoreFilesAdd = new \CriteriaCompo(); - $crMoreFilesAdd = $this->getMoreFilesCriteria($crMoreFilesAdd, $start, $limit, $sort, $order); + $crMorefilesAdd = new \CriteriaCompo(); + $crMorefilesAdd = $this->getMorefilesCriteria($crMorefilesAdd, $start, $limit, $sort, $order); - return $this->getAll($crMoreFilesAdd); + return $this->getAll($crMorefilesAdd); } /** - * Get All MoreFiles By Module Id. + * Get All Morefiles By Module Id. * * @param $modId * @param int $start @@ -124,19 +124,19 @@ public function getAllMoreFiles($start = 0, $limit = 0, $sort = 'file_id ASC, fi * * @return array */ - public function getAllMoreFilesByModuleId($modId, $start = 0, $limit = 0, $sort = 'file_id ASC, file_name', $order = 'ASC') + public function getAllMorefilesByModuleId($modId, $start = 0, $limit = 0, $sort = 'file_id ASC, file_name', $order = 'ASC') { - $crMoreFilesByModuleId = new \CriteriaCompo(); - $crMoreFilesByModuleId->add(new \Criteria('file_mid', $modId)); - $crMoreFilesByModuleId = $this->getMoreFilesCriteria($crMoreFilesByModuleId, $start, $limit, $sort, $order); + $crMorefilesByModuleId = new \CriteriaCompo(); + $crMorefilesByModuleId->add(new \Criteria('file_mid', $modId)); + $crMorefilesByModuleId = $this->getMorefilesCriteria($crMorefilesByModuleId, $start, $limit, $sort, $order); - return $this->getAll($crMoreFilesByModuleId); + return $this->getAll($crMorefilesByModuleId); } /** - * Get MoreFiles Criteria. + * Get Morefiles Criteria. * - * @param $crMoreFiles + * @param $crMorefiles * @param $start * @param $limit * @param $sort @@ -144,13 +144,13 @@ public function getAllMoreFilesByModuleId($modId, $start = 0, $limit = 0, $sort * * @return mixed */ - private function getMoreFilesCriteria($crMoreFiles, $start, $limit, $sort, $order) + private function getMorefilesCriteria($crMorefiles, $start, $limit, $sort, $order) { - $crMoreFiles->setStart($start); - $crMoreFiles->setLimit($limit); - $crMoreFiles->setSort($sort); - $crMoreFiles->setOrder($order); + $crMorefiles->setStart($start); + $crMorefiles->setLimit($limit); + $crMorefiles->setSort($sort); + $crMorefiles->setOrder($order); - return $crMoreFiles; + return $crMorefiles; } } diff --git a/class/Utility.php b/class/Utility.php index e8644acf..2c3d2a09 100644 --- a/class/Utility.php +++ b/class/Utility.php @@ -27,164 +27,20 @@ */ use XoopsModules\Modulebuilder; +use XoopsModules\Modulebuilder\Common; /** * Class Utility */ -class Utility +class Utility extends Common\SysUtility { - use Common\VersionChecks; //checkVerXoops, checkVerPhp Traits - - use Common\ServerStats; // getServerStats Trait - - use Common\FilesManagement; // Files Management Trait - - /** - * truncateHtml can truncate a string up to a number of characters while preserving whole words and HTML tags - * www.gsdesign.ro/blog/cut-html-string-without-breaking-the-tags - * www.cakephp.org - * - * @param string $text String to truncate. - * @param int $length Length of returned string, including ellipsis. - * @param string $ending Ending to be appended to the trimmed string. - * @param bool $exact If false, $text will not be cut mid-word - * @param bool $considerHtml If true, HTML tags would be handled correctly - * - * @return string Trimmed string. - */ - public static function truncateHtml($text, $length = 100, $ending = '...', $exact = false, $considerHtml = true) - { - if ($considerHtml) { - // if the plain text is shorter than the maximum length, return the whole text - if (mb_strlen(preg_replace('/<.*?' . '>/', '', $text)) <= $length) { - return $text; - } - // splits all html-tags to scanable lines - preg_match_all('/(<.+?' . '>)?([^<>]*)/s', $text, $lines, PREG_SET_ORDER); - $total_length = mb_strlen($ending); - $open_tags = []; - $truncate = ''; - foreach ($lines as $line_matchings) { - // if there is any html-tag in this line, handle it and add it (uncounted) to the output - if (!empty($line_matchings[1])) { - // if it's an "empty element" with or without xhtml-conform closing slash - if (preg_match('/^<(\s*.+?\/\s*|\s*(img|br|input|hr|area|base|basefont|col|frame|isindex|link|meta|param)(\s.+?)?)>$/is', $line_matchings[1])) { - // do nothing - // if tag is a closing tag - } elseif (preg_match('/^<\s*\/([^\s]+?)\s*>$/s', $line_matchings[1], $tag_matchings)) { - // delete tag from $open_tags list - $pos = array_search($tag_matchings[1], $open_tags, true); - if (false !== $pos) { - unset($open_tags[$pos]); - } - // if tag is an opening tag - } elseif (preg_match('/^<\s*([^\s>!]+).*?' . '>$/s', $line_matchings[1], $tag_matchings)) { - // add tag to the beginning of $open_tags list - array_unshift($open_tags, mb_strtolower($tag_matchings[1])); - } - // add html-tag to $truncate'd text - $truncate .= $line_matchings[1]; - } - // calculate the length of the plain text part of the line; handle entities as one character - $content_length = mb_strlen(preg_replace('/&[0-9a-z]{2,8};|&#[0-9]{1,7};|[0-9a-f]{1,6};/i', ' ', $line_matchings[2])); - if ($total_length + $content_length > $length) { - // the number of characters which are left - $left = $length - $total_length; - $entities_length = 0; - // search for html entities - if (preg_match_all('/&[0-9a-z]{2,8};|&#[0-9]{1,7};|[0-9a-f]{1,6};/i', $line_matchings[2], $entities, PREG_OFFSET_CAPTURE)) { - // calculate the real length of all entities in the legal range - foreach ($entities[0] as $entity) { - if ($left >= $entity[1] + 1 - $entities_length) { - $left--; - $entities_length += mb_strlen($entity[0]); - } else { - // no more characters left - break; - } - } - } - $truncate .= mb_substr($line_matchings[2], 0, $left + $entities_length); - // maximum lenght is reached, so get off the loop - break; - } - $truncate .= $line_matchings[2]; - $total_length += $content_length; - - // if the maximum length is reached, get off the loop - if ($total_length >= $length) { - break; - } - } - } else { - if (mb_strlen($text) <= $length) { - return $text; - } - $truncate = mb_substr($text, 0, $length - mb_strlen($ending)); - } - // if the words shouldn't be cut in the middle... - if (!$exact) { - // ...search the last occurance of a space... - $spacepos = mb_strrpos($truncate, ' '); - if (isset($spacepos)) { - // ...and cut the text in this position - $truncate = mb_substr($truncate, 0, $spacepos); - } - } - // add the defined ending to the text - $truncate .= $ending; - if ($considerHtml) { - // close all unclosed html-tags - foreach ($open_tags as $tag) { - $truncate .= ''; - } - } - - return $truncate; - } - - /** - * @param \Xmf\Module\Helper $helper - * @param array|null $options - * @return \XoopsFormDhtmlTextArea|\XoopsFormEditor - */ - public static function getEditor($helper = null, $options = null) - { - /** @var Modulebuilder\Helper $helper */ - if (null === $options) { - $options = []; - $options['name'] = 'Editor'; - $options['value'] = 'Editor'; - $options['rows'] = 10; - $options['cols'] = '100%'; - $options['width'] = '100%'; - $options['height'] = '400px'; - } - - $isAdmin = $helper->isUserAdmin(); - - if (class_exists('XoopsFormEditor')) { - if ($isAdmin) { - $descEditor = new \XoopsFormEditor(ucfirst($options['name']), $helper->getConfig('editorAdmin'), $options, $nohtml = false, $onfailure = 'textarea'); - } else { - $descEditor = new \XoopsFormEditor(ucfirst($options['name']), $helper->getConfig('editorUser'), $options, $nohtml = false, $onfailure = 'textarea'); - } - } else { - $descEditor = new \XoopsFormDhtmlTextArea(ucfirst($options['name']), $options['name'], $options['value'], '100%', '100%'); - } - - // $form->addElement($descEditor); - - return $descEditor; - } - //--------------- Custom module methods ----------------------------- /** * @param $about * @return string */ - public static function MakeDonationForm($about) + public static function makeDonationForm($about) { $donationform = [ 0 => '
', diff --git a/commonfiles/class/Helper.php b/commonfiles/class/Helper.php index 164ddc98..cdff5d52 100644 --- a/commonfiles/class/Helper.php +++ b/commonfiles/class/Helper.php @@ -70,7 +70,7 @@ public function getDirname() */ public function getHandler($name) { - $class = '\\XoopsModules\\' . ucfirst(mb_strtolower(basename(dirname(__DIR__)))) . '\\' . $name . 'Handler'; + $class = __NAMESPACE__ . '\\' . ucfirst($name) . 'Handler'; if (!class_exists($class)) { throw new \RuntimeException("Class '$class' not found"); } diff --git a/docs/changelog.txt b/docs/changelog.txt index 689bcb9c..384332ea 100644 --- a/docs/changelog.txt +++ b/docs/changelog.txt @@ -1,7 +1,18 @@ +
3.03 Alpha 3 [WORK IN PROGRESS - NOT RELEASED]
Dev: XOOPS 2.5.11, PHP 7.4.5 +
+- fix class names to case-sensitive (heyula/mamba) +- fix folder names to case-sensitive (mamba) +- add folder & file checkers (mamba) +- add SysUtility class (mamba) +- fix $pathIcon16 (mamba) +- add __NAMESPACE__ to Helper (mamba) + +
3.03 Alpha 2 [WORK IN PROGRESS - NOT RELEASED]
Dev: XOOPS 2.5.11, PHP 7.4.5
- rename to ModuleBuilder (mamba) +
3.02 Alpha 1 [WORK IN PROGRESS - NOT RELEASED]
Dev: XOOPS 2.5.11, PHP 7.4.2
work done by goffy: diff --git a/include/common.php b/include/common.php index ea1f89c2..b514041d 100644 --- a/include/common.php +++ b/include/common.php @@ -63,5 +63,5 @@ define('TDMC_UPLOAD_IMGTAB_URL', TDMC_UPLOAD_URL . '/images/tables'); // Xoops Request include_once XOOPS_ROOT_PATH . '/class/xoopsrequest.php'; -include_once TDMC_PATH . '/include/functions.php'; -include_once TDMC_PATH . '/class/helper.php'; +//include_once TDMC_PATH . '/include/functions.php'; + diff --git a/language/english/directorychecker.php b/language/english/directorychecker.php new file mode 100644 index 00000000..96a1d5f6 --- /dev/null +++ b/language/english/directorychecker.php @@ -0,0 +1,23 @@ +Available"); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_NOTAVAILABLE', "Not available"); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_NOTWRITABLE', " should have permission ( %d ), but it has ( %d )"); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_CREATETHEDIR', 'Create it'); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_SETMPERM', 'Set the permission'); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_DIRCREATED', 'The directory has been created'); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_DIRNOTCREATED', 'The directory cannot be created'); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_PERMSET', 'The permission has been set'); +define('CO_' . $moduleDirNameUpper . '_' . 'DC_PERMNOTSET', 'The permission cannot be set'); diff --git a/language/english/filechecker.php b/language/english/filechecker.php new file mode 100644 index 00000000..128abc00 --- /dev/null +++ b/language/english/filechecker.php @@ -0,0 +1,24 @@ +Available"); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_NOTAVAILABLE', "Not available"); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_NOTWRITABLE', "Should have permission ( %d ), but it has ( %d )"); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_COPYTHEFILE', 'Copy it'); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_CREATETHEFILE', 'Create it'); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_SETMPERM', 'Set the permission'); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_FILECOPIED', 'The file has been copied'); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_FILENOTCOPIED', 'The file cannot be copied'); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_PERMSET', 'The permission has been set'); +define('CO_' . $moduleDirNameUpper . '_' . 'FC_PERMNOTSET', 'The permission cannot be set'); diff --git a/testdata/english/modulebuilder_modules.yml b/testdata/english/modulebuilder_modules.yml index d5903e60..95bc6546 100644 --- a/testdata/english/modulebuilder_modules.yml +++ b/testdata/english/modulebuilder_modules.yml @@ -19,7 +19,7 @@ mod_release_file: 'release_info file' mod_manual: 'link to manual file' mod_manual_file: install.txt - mod_image: MyModule_logo.png + mod_image: logoModule.png mod_demo_site_url: 'https://xoops.org' mod_demo_site_name: 'XOOPS Demo Site' mod_support_url: 'https://xoops.org/modules/newbb' diff --git a/testdata/german/modulebuilder_modules.yml b/testdata/german/modulebuilder_modules.yml index d5903e60..95bc6546 100644 --- a/testdata/german/modulebuilder_modules.yml +++ b/testdata/german/modulebuilder_modules.yml @@ -19,7 +19,7 @@ mod_release_file: 'release_info file' mod_manual: 'link to manual file' mod_manual_file: install.txt - mod_image: MyModule_logo.png + mod_image: logoModule.png mod_demo_site_url: 'https://xoops.org' mod_demo_site_name: 'XOOPS Demo Site' mod_support_url: 'https://xoops.org/modules/newbb' diff --git a/testdata/mymodule2/class/Helper.php b/testdata/mymodule2/class/Helper.php index 86e3ce71..635996d6 100644 --- a/testdata/mymodule2/class/Helper.php +++ b/testdata/mymodule2/class/Helper.php @@ -72,7 +72,7 @@ public function getHandler($name) { $ret = false; - $class = '\\XoopsModules\\' . ucfirst(mb_strtolower(basename(dirname(__DIR__)))) . '\\' . $name . 'Handler'; + $class = __NAMESPACE__ . '\\' . ucfirst($name) . 'Handler'; if (!class_exists($class)) { throw new \RuntimeException("Class '$class' not found"); } diff --git a/testdata/mymodule3/class/Helper.php b/testdata/mymodule3/class/Helper.php index 5bb9d0e6..251eaea0 100644 --- a/testdata/mymodule3/class/Helper.php +++ b/testdata/mymodule3/class/Helper.php @@ -70,7 +70,7 @@ public function getDirname() */ public function getHandler($name) { - $class = '\\XoopsModules\\' . ucfirst(mb_strtolower(basename(dirname(__DIR__)))) . '\\' . $name . 'Handler'; + $class = __NAMESPACE__ . '\\' . ucfirst($name) . 'Handler'; if (!class_exists($class)) { throw new \RuntimeException("Class '$class' not found"); } diff --git a/xoops_version.php b/xoops_version.php index a765f1fc..5aecbc67 100644 --- a/xoops_version.php +++ b/xoops_version.php @@ -25,8 +25,8 @@ $moduleDirNameUpper = mb_strtoupper($moduleDirName); $modversion['version'] = 3.03; -$modversion['module_status'] = 'Alpha 2'; -$modversion['release_date'] = '2020/05/09'; +$modversion['module_status'] = 'Alpha 3'; +$modversion['release_date'] = '2020/05/10'; $modversion['name'] = _MI_MODULEBUILDER_NAME; $modversion['description'] = _MI_MODULEBUILDER_DESC; $modversion['author'] = 'Xoops TDM';