0
0
mirror of https://github.com/salesagility/SuiteCRM.git synced 2024-11-22 07:52:36 +00:00
salesagility_SuiteCRM/modules/ModuleBuilder/parsers/ParserFactory.php
2023-07-18 15:53:09 +01:00

187 lines
8.2 KiB
PHP
Executable File

<?php
/**
*
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
*
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by the
* Free Software Foundation with the addition of the following permission added
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
* details.
*
* You should have received a copy of the GNU Affero General Public License along with
* this program; if not, see http://www.gnu.org/licenses or write to the Free
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA.
*
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
*/
if (!defined('sugarEntry') || !sugarEntry) {
die('Not A Valid Entry Point');
}
require_once 'modules/ModuleBuilder/parsers/constants.php' ;
#[\AllowDynamicProperties]
class ParserFactory
{
/**
* Create a new parser
*
* @param string $view The view, for example EditView or ListView. For search views, use advanced_search or basic_search
* @param string $moduleName Module name
* @param string $packageName Package name. If present implies that we are being called from ModuleBuilder
* @return AbstractMetaDataParser
*/
public static function getParser($view, $moduleName, $packageName = null, $subpanelName = null)
{
$GLOBALS [ 'log' ]->info("ParserFactory->getParser($view,$moduleName,$packageName,$subpanelName )") ;
$sm = null;
$lView = strtolower($view);
if (empty($packageName) || ($packageName == 'studio')) {
$packageName = null ;
//For studio modules, check for view parser overrides
$parser = self::checkForStudioParserOverride($view, $moduleName, $packageName);
if ($parser) {
return $parser;
}
$sm = StudioModuleFactory::getStudioModule($moduleName);
//If we didn't find a specofic parser, see if there is a view to type mapping
foreach ($sm->sources as $file => $def) {
if (!empty($def['view']) && $def['view'] == $view && !empty($def['type'])) {
$lView = strtolower($def['type']);
break;
}
}
}
switch ($lView) {
case MB_EDITVIEW:
case MB_DETAILVIEW:
case MB_QUICKCREATE:
require_once 'modules/ModuleBuilder/parsers/views/GridLayoutMetaDataParser.php' ;
return new GridLayoutMetaDataParser($view, $moduleName, $packageName) ;
case MB_BASICSEARCH:
case MB_ADVANCEDSEARCH:
require_once 'modules/ModuleBuilder/parsers/views/SearchViewMetaDataParser.php' ;
return new SearchViewMetaDataParser($view, $moduleName, $packageName) ;
case MB_LISTVIEW:
if ($subpanelName == null) {
require_once 'modules/ModuleBuilder/parsers/views/ListLayoutMetaDataParser.php' ;
return new ListLayoutMetaDataParser(MB_LISTVIEW, $moduleName, $packageName) ;
} else {
require_once 'modules/ModuleBuilder/parsers/views/SubpanelMetaDataParser.php' ;
return new SubpanelMetaDataParser($subpanelName, $moduleName, $packageName) ;
}
// no break
case MB_DASHLET:
case MB_DASHLETSEARCH:
require_once 'modules/ModuleBuilder/parsers/views/DashletMetaDataParser.php' ;
return new DashletMetaDataParser($view, $moduleName, $packageName);
case MB_POPUPLIST:
case MB_POPUPSEARCH:
require_once 'modules/ModuleBuilder/parsers/views/PopupMetaDataParser.php' ;
return new PopupMetaDataParser($view, $moduleName, $packageName);
case MB_LABEL:
require_once 'modules/ModuleBuilder/parsers/parser.label.php' ;
return new ParserLabel($moduleName, $packageName) ;
case MB_VISIBILITY:
require_once 'modules/ModuleBuilder/parsers/parser.visibility.php' ;
return new ParserVisibility($moduleName, $packageName) ;
default:
$parser = self::checkForParserClass($view, $moduleName, $packageName);
if ($parser) {
return $parser;
}
}
$GLOBALS [ 'log' ]->fatal("ParserFactory: cannot create ModuleBuilder Parser $view") ;
}
protected static function checkForParserClass($view, $moduleName, $packageName, $nameOverride = false)
{
$prefix = '';
if (!is_null($packageName)) {
$prefix = empty($packageName) ? 'build' :'modify';
}
$fileNames = array(
"custom/modules/$moduleName/parsers/parser." . strtolower($prefix . $view) . ".php",
"modules/$moduleName/parsers/parser." . strtolower($prefix . $view) . ".php",
"custom/modules/ModuleBuilder/parsers/parser." . strtolower($prefix . $view) . ".php",
"modules/ModuleBuilder/parsers/parser." . strtolower($prefix . $view) . ".php",
);
foreach ($fileNames as $fileName) {
if (file_exists($fileName)) {
require_once $fileName ;
$class = 'Parser' . $prefix . ucfirst($view) ;
if (class_exists($class)) {
$GLOBALS [ 'log' ]->debug('Using ModuleBuilder Parser ' . $fileName) ;
$parser = new $class() ;
return $parser ;
}
}
}
return false;
}
/**
* @param string $view
* @param string $moduleName
* @param string $packageName
* @return bool|SugarView
*/
protected static function checkForStudioParserOverride($view, $moduleName, $packageName)
{
require_once('modules/ModuleBuilder/Module/StudioModuleFactory.php');
$sm = StudioModuleFactory::getStudioModule($moduleName);
foreach ($sm->sources as $file => $def) {
if (!empty($def['view']) && $def['view'] == strtolower($view) && !empty($def['parser'])) {
$pName = $def['parser'];
$path = "modules/ModuleBuilder/parsers/views/{$pName}.php";
if (file_exists("custom/$path")) {
require_once("custom/$path");
} else {
if (file_exists($path)) {
require_once($path);
}
}
if (class_exists($pName)) {
return new $pName($view, $moduleName, $packageName);
}
//If it wasn't defined directly, check for a generic parser name for the view
$parser = self::checkForParserClass($view, $moduleName, $packageName);
if ($parser) {
return $parser;
}
}
}
return false;
}
}