]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - include/utils/autoloader.php
Release 6.4.1
[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
45         );
46
47         public static $noAutoLoad = array(
48                 'Tracker'=>true,
49         );
50
51         public static $moduleMap = array();
52
53     public static function autoload($class)
54         {
55                 $uclass = ucfirst($class);
56                 if(!empty(SugarAutoLoader::$noAutoLoad[$class])){
57                         return false;
58                 }
59                 if(!empty(SugarAutoLoader::$map[$uclass])){
60                         require_once(SugarAutoLoader::$map[$uclass]);
61                         return true;
62                 }
63
64                 if(empty(SugarAutoLoader::$moduleMap)){
65                         if(isset($GLOBALS['beanFiles'])){
66                                 SugarAutoLoader::$moduleMap = $GLOBALS['beanFiles'];
67                         }else{
68                                 include('include/modules.php');
69                                 SugarAutoLoader::$moduleMap = $beanFiles;
70                         }
71                 }
72                 if(!empty(SugarAutoLoader::$moduleMap[$class])){
73                         require_once(SugarAutoLoader::$moduleMap[$class]);
74                         return true;
75                 }
76         $viewPath = self::getFilenameForViewClass($class);
77         if (!empty($viewPath))
78         {
79             require_once($viewPath);
80             return true;
81         }
82         $reportWidget = self::getFilenameForSugarWidget($class);
83         if (!empty($reportWidget))
84         {
85             require_once($reportWidget);
86             return true;
87         }
88
89                 return false;
90         }
91
92     protected static function getFilenameForViewClass($class)
93     {
94         $module = false;
95         if (!empty($_REQUEST['module']) && substr($class, 0, strlen($_REQUEST['module'])) == $_REQUEST['module'])
96         {
97             //This is a module view
98             $module = $_REQUEST['module'];
99             $class = substr($class, strlen($module));
100         }
101
102         if (substr($class, 0, 4) == "View")
103         {
104             $view = strtolower(substr($class, 4));
105             if ($module)
106             {
107                 $modulepath = "modules/$module/views/view.$view.php";
108                 if (file_exists("custom/$modulepath"))
109                     return "custom/$modulepath";
110                 if (file_exists($modulepath))
111                     return $modulepath;
112             } else {
113                 $basepath = "include/MVC/View/views/view.$view.php";
114                 if (file_exists("custom/$basepath")){
115                     return "custom/$basepath";
116                 }
117                 if (file_exists($basepath)) {
118                     return $basepath;
119                 }
120             }
121         }
122     }
123
124     /**
125      * getFilenameForSugarWidget
126      * This method attempts to autoload classes starting with name "SugarWidget".  It first checks for the file
127      * in custom/include/generic/SugarWidgets directory and if not found defaults to include/generic/SugarWidgets.
128      * This method is used so that we can easily customize and extend these SugarWidget classes.
129      *
130      * @static
131      * @param $class String name of the class to load
132      * @return String file of the SugarWidget class; false if none found
133      */
134     protected static function getFilenameForSugarWidget($class)
135     {
136         //Only bother to check if the class name starts with SugarWidget
137         if(strpos($class, 'SugarWidget') !== false)
138         {
139             if(strpos($class, 'SugarWidgetField') !== false)
140             {
141                 //We need to lowercase the portion after SugarWidgetField
142                 $name = substr($class, 16);
143                 if(!empty($name))
144                 {
145                     $class = 'SugarWidgetField' . strtolower($name);
146                 }
147             }
148
149             $file = get_custom_file_if_exists("include/generic/SugarWidgets/{$class}.php");
150             if(file_exists($file))
151             {
152                return $file;
153             }
154         }
155         return false;
156     }
157
158         public static function loadAll(){
159                 foreach(SugarAutoLoader::$map as $class=>$file){
160                         require_once($file);
161                 }
162
163                 if(isset($GLOBALS['beanFiles'])){
164                         $files = $GLOBALS['beanFiles'];
165                 }else{
166                         include('include/modules.php');
167                         $files = $beanList;
168                 }
169                 foreach(SugarAutoLoader::$map as $class=>$file){
170                         require_once($file);
171                 }
172
173         }
174 }
175 ?>