]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - include/utils/autoloader.php
Release 6.5.0
[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-2012 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
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                 return false;
91         }
92
93     protected static function getFilenameForViewClass($class)
94     {
95         $module = false;
96         if (!empty($_REQUEST['module']) && substr($class, 0, strlen($_REQUEST['module'])) == $_REQUEST['module'])
97         {
98             //This is a module view
99             $module = $_REQUEST['module'];
100             $class = substr($class, strlen($module));
101         }
102
103         if (substr($class, 0, 4) == "View")
104         {
105             $view = strtolower(substr($class, 4));
106             if ($module)
107             {
108                 $modulepath = "modules/$module/views/view.$view.php";
109                 if (file_exists("custom/$modulepath"))
110                     return "custom/$modulepath";
111                 if (file_exists($modulepath))
112                     return $modulepath;
113             } else {
114                 $basepath = "include/MVC/View/views/view.$view.php";
115                 if (file_exists("custom/$basepath")){
116                     return "custom/$basepath";
117                 }
118                 if (file_exists($basepath)) {
119                     return $basepath;
120                 }
121             }
122         }
123     }
124
125     /**
126      * getFilenameForSugarWidget
127      * This method attempts to autoload classes starting with name "SugarWidget".  It first checks for the file
128      * in custom/include/generic/SugarWidgets directory and if not found defaults to include/generic/SugarWidgets.
129      * This method is used so that we can easily customize and extend these SugarWidget classes.
130      *
131      * @static
132      * @param $class String name of the class to load
133      * @return String file of the SugarWidget class; false if none found
134      */
135     protected static function getFilenameForSugarWidget($class)
136     {
137         //Only bother to check if the class name starts with SugarWidget
138         if(strpos($class, 'SugarWidget') !== false)
139         {
140             if(strpos($class, 'SugarWidgetField') !== false)
141             {
142                 //We need to lowercase the portion after SugarWidgetField
143                 $name = substr($class, 16);
144                 if(!empty($name))
145                 {
146                     $class = 'SugarWidgetField' . strtolower($name);
147                 }
148             }
149
150             $file = get_custom_file_if_exists("include/generic/SugarWidgets/{$class}.php");
151             if(file_exists($file))
152             {
153                return $file;
154             }
155         }
156         return false;
157     }
158
159         public static function loadAll(){
160                 foreach(SugarAutoLoader::$map as $class=>$file){
161                         require_once($file);
162                 }
163
164                 if(isset($GLOBALS['beanFiles'])){
165                         $files = $GLOBALS['beanFiles'];
166                 }else{
167                         include('include/modules.php');
168                         $files = $beanList;
169                 }
170                 foreach(SugarAutoLoader::$map as $class=>$file){
171                         require_once($file);
172                 }
173
174         }
175 }
176 ?>