33
2
mirror of https://github.com/joomla-extensions/jedchecker.git synced 2025-01-03 22:57:21 +00:00

add some comments

This commit is contained in:
Denis Ryabov 2021-03-11 01:56:04 +03:00
parent 7a36ce7582
commit d102979258

View File

@ -112,15 +112,19 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
return false; return false;
} }
// Get extension name (element) // Get extension type
$type = (string) $xml['type']; $type = (string) $xml['type'];
// Get extension's element name (simulates work of Joomla's installer)
// Firstly, check for <element> node
if (isset($xml->element)) if (isset($xml->element))
{ {
$extension = (string) $xml->element; $extension = (string) $xml->element;
} }
else else
{ {
// Otherwise, use <name> node or plugin/module attribute in the <files> section
$extension = (string) $xml->name; $extension = (string) $xml->name;
if (isset($xml->files)) if (isset($xml->files))
{ {
@ -133,13 +137,18 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
} }
} }
} }
// Filter extension's element name
$extension = strtolower(JFilterInput::getInstance()->clean($extension, 'cmd')); $extension = strtolower(JFilterInput::getInstance()->clean($extension, 'cmd'));
// Component's element name starts with com_
if ($type === 'component' && strpos($extension, 'com_') !== 0) if ($type === 'component' && strpos($extension, 'com_') !== 0)
{ {
$extension = 'com_' . $extension; $extension = 'com_' . $extension;
} }
if ($type === 'plugin' && isset($xml['group'])) // Plugin's element name starts with com_
if ($type === 'plugin' && isset($xml['group']) && strpos($extension, 'plg_') !== 0)
{ {
$extension = 'plg_' . $xml['group'] . '_' . $extension; $extension = 'plg_' . $xml['group'] . '_' . $extension;
} }
@ -151,6 +160,7 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
$lang_dir = dirname($file); $lang_dir = dirname($file);
$lang_tag = 'en-GB'; // $lang->getDefault(); $lang_tag = 'en-GB'; // $lang->getDefault();
// Populate list of directories to look for
$lookup_lang_dirs = array(); $lookup_lang_dirs = array();
if (isset($xml->administration->files['folder'])) if (isset($xml->administration->files['folder']))
@ -240,10 +250,12 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
if (stripos($extension_name, 'joomla') === 0) if (stripos($extension_name, 'joomla') === 0)
{ {
// An extension name can't start with the word "Joomla"
$this->report->addError($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_NAME_JOOMLA', $extension_name)); $this->report->addError($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_NAME_JOOMLA', $extension_name));
} }
elseif (stripos($extension_name, 'joom') !== false) elseif (stripos($extension_name, 'joom') !== false)
{ {
// Extensions that use "Joomla" or a derivative of Joomla in the extension name need to be licensed by OSM
$this->report->addWarning($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_NAME_JOOMLA_DERIVATIVE', $extension_name)); $this->report->addWarning($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_NAME_JOOMLA_DERIVATIVE', $extension_name));
} }
@ -262,6 +274,7 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
if (!in_array($domain, $approvedDomains, true)) if (!in_array($domain, $approvedDomains, true))
{ {
// Extensions that use "Joomla" or a derivative of Joomla in the domain name need to be licensed by OSM
$this->report->addError($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_URL_JOOMLA_DERIVATIVE', $url)); $this->report->addError($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_URL_JOOMLA_DERIVATIVE', $url));
} }
} }
@ -270,6 +283,7 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
if ($type === 'component' && isset($xml->administration->menu)) if ($type === 'component' && isset($xml->administration->menu))
{ {
$menu_name = $lang->_((string) $xml->administration->menu); $menu_name = $lang->_((string) $xml->administration->menu);
// Do name the Component's admin menu the same as the extension name
if ($extension_name !== $menu_name) if ($extension_name !== $menu_name)
{ {
$this->report->addWarning($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_NAME_ADMIN_MENU', $menu_name, $extension_name)); $this->report->addWarning($file, JText::sprintf('COM_JEDCHECKER_INFO_XML_NAME_ADMIN_MENU', $menu_name, $extension_name));
@ -278,6 +292,7 @@ class JedcheckerRulesXMLinfo extends JEDcheckerRule
if ($type === 'plugin') if ($type === 'plugin')
{ {
// The name of your plugin must comply with the JED naming conventions - plugins in the form “{Type} - {Extension Name}”.
$parts = explode(' - ', $extension_name, 2); $parts = explode(' - ', $extension_name, 2);
$extension_name_group = isset($parts[1]) ? strtolower(preg_replace('/\s/', '', $parts[0])) : false; $extension_name_group = isset($parts[1]) ? strtolower(preg_replace('/\s/', '', $parts[0])) : false;
$group = (string) $xml['group']; $group = (string) $xml['group'];