%PDF- %PDF-
| Direktori : /var/www/crm/modules/ModuleBuilder/parsers/ |
| Current File : /var/www/crm/modules/ModuleBuilder/parsers/ParserFactory.php |
<?php
if (! defined ( 'sugarEntry' ) || ! sugarEntry)
die ( 'Not A Valid Entry Point' ) ;
/*********************************************************************************
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
*
* 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. If the display of the logo is not reasonably feasible for
* technical reasons, the Appropriate Legal Notices must display the words
* "Powered by SugarCRM".
********************************************************************************/
require_once 'modules/ModuleBuilder/parsers/constants.php' ;
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 ) ;
}
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;
}
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;
}
}
?>