]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - include/utils/autoloader.php
Release 6.5.16
[Github/sugarcrm.git] / include / utils / autoloader.php
1 <?php
2 /*********************************************************************************
3  * SugarCRM Community Edition is a customer relationship management program developed by
4  * SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
5  * 
6  * This program is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU Affero General Public License version 3 as published by the
8  * Free Software Foundation with the addition of the following permission added
9  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
11  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12  * 
13  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
16  * details.
17  * 
18  * You should have received a copy of the GNU Affero General Public License along with
19  * this program; if not, see http://www.gnu.org/licenses or write to the Free
20  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21  * 02110-1301 USA.
22  * 
23  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
24  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
25  * 
26  * The interactive user interfaces in modified source and object code versions
27  * of this program must display Appropriate Legal Notices, as required under
28  * Section 5 of the GNU Affero General Public License version 3.
29  * 
30  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31  * these Appropriate Legal Notices must retain the display of the "Powered by
32  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
33  * technical reasons, the Appropriate Legal Notices must display the words
34  * "Powered by SugarCRM".
35  ********************************************************************************/
36
37 class SugarAutoLoader{
38
39         public static $map = array(
40                 'XTemplate'=>'XTemplate/xtpl.php',
41                 'ListView'=>'include/ListView/ListView.php',
42                 'Sugar_Smarty'=>'include/Sugar_Smarty.php',
43                 'Javascript'=>'include/javascript/javascript.php',
44         'SugarSearchEngineFullIndexer'=>'include/SugarSearchEngine/SugarSearchEngineFullIndexer.php',
45         'SugarSearchEngineSyncIndexer'=>'include/SugarSearchEngine/SugarSearchEngineSyncIndexer.php',
46         );
47
48         public static $noAutoLoad = array(
49                 'Tracker'=>true,
50         );
51
52         public static $moduleMap = array();
53
54     public static function autoload($class)
55         {
56                 $uclass = ucfirst($class);
57                 if(!empty(SugarAutoLoader::$noAutoLoad[$class])){
58                         return false;
59                 }
60                 if(!empty(SugarAutoLoader::$map[$uclass])){
61                         require_once(SugarAutoLoader::$map[$uclass]);
62                         return true;
63                 }
64
65                 if(empty(SugarAutoLoader::$moduleMap)){
66                         if(isset($GLOBALS['beanFiles'])){
67                                 SugarAutoLoader::$moduleMap = $GLOBALS['beanFiles'];
68                         }else{
69                                 include('include/modules.php');
70                                 SugarAutoLoader::$moduleMap = $beanFiles;
71                         }
72                 }
73                 if(!empty(SugarAutoLoader::$moduleMap[$class])){
74                         require_once(SugarAutoLoader::$moduleMap[$class]);
75                         return true;
76                 }
77         $viewPath = self::getFilenameForViewClass($class);
78         if (!empty($viewPath))
79         {
80             require_once($viewPath);
81             return true;
82         }
83         $reportWidget = self::getFilenameForSugarWidget($class);
84         if (!empty($reportWidget))
85         {
86             require_once($reportWidget);
87             return true;
88         }
89
90
91                 return false;
92         }
93
94     protected static function getFilenameForViewClass($class)
95     {
96         $module = false;
97         if (!empty($_REQUEST['module']) && substr($class, 0, strlen($_REQUEST['module'])) == $_REQUEST['module'])
98         {
99             //This is a module view
100             $module = $_REQUEST['module'];
101             $class = substr($class, strlen($module));
102         }
103
104         if (substr($class, 0, 4) == "View")
105         {
106             $view = strtolower(substr($class, 4));
107             if ($module)
108             {
109                 $modulepath = "modules/$module/views/view.$view.php";
110                 if (file_exists("custom/$modulepath"))
111                     return "custom/$modulepath";
112                 if (file_exists($modulepath))
113                     return $modulepath;
114             } else {
115                 $basepath = "include/MVC/View/views/view.$view.php";
116                 if (file_exists("custom/$basepath")){
117                     return "custom/$basepath";
118                 }
119                 if (file_exists($basepath)) {
120                     return $basepath;
121                 }
122             }
123         }
124     }
125
126     /**
127      * getFilenameForSugarWidget
128      * This method attempts to autoload classes starting with name "SugarWidget".  It first checks for the file
129      * in custom/include/generic/SugarWidgets directory and if not found defaults to include/generic/SugarWidgets.
130      * This method is used so that we can easily customize and extend these SugarWidget classes.
131      *
132      * @static
133      * @param $class String name of the class to load
134      * @return String file of the SugarWidget class; false if none found
135      */
136     protected static function getFilenameForSugarWidget($class)
137     {
138         //Only bother to check if the class name starts with SugarWidget
139         if(strpos($class, 'SugarWidget') !== false)
140         {
141             if(strpos($class, 'SugarWidgetField') !== false)
142             {
143                 //We need to lowercase the portion after SugarWidgetField
144                 $name = substr($class, 16);
145                 if(!empty($name))
146                 {
147                     $class = 'SugarWidgetField' . strtolower($name);
148                 }
149             }
150
151             $file = get_custom_file_if_exists("include/generic/SugarWidgets/{$class}.php");
152             if(file_exists($file))
153             {
154                return $file;
155             }
156         }
157         return false;
158     }
159
160
161         public static function loadAll(){
162                 foreach(SugarAutoLoader::$map as $class=>$file){
163                         require_once($file);
164                 }
165
166                 if(isset($GLOBALS['beanFiles'])){
167                         $files = $GLOBALS['beanFiles'];
168                 }else{
169                         include('include/modules.php');
170                         $files = $beanList;
171                 }
172                 foreach(SugarAutoLoader::$map as $class=>$file){
173                         require_once($file);
174                 }
175
176         }
177 }
178 ?>