]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - modules/ModuleBuilder/parsers/relationships/RelationshipFactory.php
Release 6.5.0
[Github/sugarcrm.git] / modules / ModuleBuilder / parsers / relationships / RelationshipFactory.php
1 <?php
2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4  * SugarCRM Community Edition is a customer relationship management program developed by
5  * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
6  * 
7  * This program is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU Affero General Public License version 3 as published by the
9  * Free Software Foundation with the addition of the following permission added
10  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13  * 
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
17  * details.
18  * 
19  * You should have received a copy of the GNU Affero General Public License along with
20  * this program; if not, see http://www.gnu.org/licenses or write to the Free
21  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22  * 02110-1301 USA.
23  * 
24  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26  * 
27  * The interactive user interfaces in modified source and object code versions
28  * of this program must display Appropriate Legal Notices, as required under
29  * Section 5 of the GNU Affero General Public License version 3.
30  * 
31  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32  * these Appropriate Legal Notices must retain the display of the "Powered by
33  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34  * technical reasons, the Appropriate Legal Notices must display the words
35  * "Powered by SugarCRM".
36  ********************************************************************************/
37
38
39 require_once 'modules/ModuleBuilder/parsers/constants.php' ;
40
41 class RelationshipFactory
42 {
43
44     /*
45      * Construct a new relationship of type as provided by the $definition
46      * @param array $definition Complete definition of the relationship, as specified by AbstractRelationship::keys
47      */
48     static function newRelationship ($definition = array())
49     {
50         // handle the case where a relationship_type is not provided - set it to Many-To-Many as this was the usual type in ModuleBuilder
51         if (! isset ( $definition [ 'relationship_type' ] ))
52             $definition [ 'relationship_type' ] = MB_MANYTOMANY ;
53             
54         if (!empty ($definition['for_activities']) && $definition['for_activities'] == true) {
55                 require_once 'modules/ModuleBuilder/parsers/relationships/ActivitiesRelationship.php';
56                 return new ActivitiesRelationship ($definition);
57         }
58         
59         switch ( strtolower ( $definition [ 'relationship_type' ] ))
60         {
61             case strtolower ( MB_ONETOONE ) :
62                 require_once 'modules/ModuleBuilder/parsers/relationships/OneToOneRelationship.php' ;
63                 return new OneToOneRelationship ( $definition ) ;
64             
65             case strtolower ( MB_ONETOMANY ) :
66                 require_once 'modules/ModuleBuilder/parsers/relationships/OneToManyRelationship.php' ;
67                 return new OneToManyRelationship ( $definition ) ;
68                 
69             case strtolower ( MB_MANYTOONE ) :
70                 require_once 'modules/ModuleBuilder/parsers/relationships/ManyToOneRelationship.php' ;
71                 return new ManyToOneRelationship ( $definition ) ;
72             
73             // default case is Many-To-Many as this was the only type ModuleBuilder could create and so much of the MB code assumes Many-To-Many
74             default :
75                 $definition [ 'relationship_type' ] = MB_MANYTOMANY ;
76                 require_once 'modules/ModuleBuilder/parsers/relationships/ManyToManyRelationship.php' ;
77                 return new ManyToManyRelationship ( $definition ) ;
78         }
79     
80     }
81 }
82 ?>