diff options
-rw-r--r-- | engine/lib/entities.php | 79 | ||||
-rw-r--r-- | engine/schema/mysql.sql | 6 |
2 files changed, 68 insertions, 17 deletions
diff --git a/engine/lib/entities.php b/engine/lib/entities.php index e9f1f52cc..f6ee90092 100644 --- a/engine/lib/entities.php +++ b/engine/lib/entities.php @@ -25,7 +25,7 @@ * Any field not appearing in this will be viewed as a */ protected $attributes; - + /** * Initialise the attributes array. * This is vital to distinguish between metadata and base parameters. @@ -133,6 +133,9 @@ return create_metadata($this->getGUID(), $name, $value, $value_type, $this->getOwner()); } + /** + * Clear metadata. + */ public function clearMetaData() { return clear_metadata($this->getGUID()); @@ -292,15 +295,17 @@ * * TODO: Move to a nicer place? * + * @param string $type * @param string $subtype */ - function get_subtype_id($subtype) + function get_subtype_id($type, $subtype) { global $CONFIG; + $type = sanitise_string($type); $subtype = sanitise_string($subtype); - $result = get_data_row("SELECT * from {$CONFIG->dbprefix}entity_subtypes where subtype='$subtype'"); + $result = get_data_row("SELECT * from {$CONFIG->dbprefix}entity_subtypes where type='$type' and subtype='$subtype'"); if ($result) return $result->id; @@ -328,20 +333,45 @@ } /** + * This function tests to see if a subtype has a registered class handler. + * + * @param string $type The type + * @param string $subtype The subtype + * @return a class name or null + */ + function get_subtype_class($type, $subtype) + { + global $CONFIG; + + $type = sanitise_string($type); + $subtype = sanitise_string($subtype); + + $result = get_data_row("SELECT * from {$CONFIG->dbprefix}entity_subtypes where type='$type' and subtype='$subtype'"); + if ($result) + return $result->class; + + return NULL; + } + + /** * This function will register a new subtype, returning its ID as required. * - * @param string $subtype + * @param string $type The type you're subtyping + * @param string $subtype The subtype label + * @param string $class Optional class handler (if you don't want it handled by the generic elgg handler for the type) */ - function add_subtype($subtype) + function add_subtype($type, $subtype, $class = "") { global $CONFIG; + $type = sanitise_string($type); $subtype = sanitise_string($subtype); + $class = sanitise_string($class); - $id = get_subtype_id($subtype); + $id = get_subtype_id($type, $subtype); if (!$id) - return insert_data("insert into {$CONFIG->dbprefix}entity_subtypes (subtype) values ('$subtype')"); + return insert_data("insert into {$CONFIG->dbprefix}entity_subtypes (type, subtype, class) values ('$type','$subtype','$class')"); return $id; } @@ -418,14 +448,31 @@ { if (!($row instanceof stdClass)) return $row; - - switch ($row->type) + + // See if there are any registered subtype handler classes for this type and subtype + $classname = get_subtype_class($row->type, $row->subtype); + if ($classname!="") { - case 'object' : return new ElggObject($row); - case 'user' : return new ElggUser($row); - case 'collection' : return new ElggCollection($row); - case 'site' : return new ElggSite($row); - default: default : throw new InstallationException("Type {$row->type} is not supported. This indicates an error in your installation, most likely caused by an incomplete upgrade."); + $tmp = $classname($row); + + if (!($tmp instanceof ElggEntity)) + throw new ClassException("$classname is not an ElggEntity."); + + } + else + { + switch ($row->type) + { + case 'object' : + return new ElggObject($row); + case 'user' : + return new ElggUser($row); + case 'collection' : + return new ElggCollection($row); + case 'site' : + return new ElggSite($row); + default: default : throw new InstallationException("Type {$row->type} is not supported. This indicates an error in your installation, most likely caused by an incomplete upgrade."); + } } return false; @@ -456,7 +503,7 @@ global $CONFIG; $type = sanitise_string($type); - $subtype = get_subtype_id($subtype); + $subtype = get_subtype_id($type, $subtype); $owner_guid = (int)$owner_guid; $order_by = sanitise_string($order_by); $limit = (int)$limit; @@ -503,7 +550,7 @@ $relationship_guid = (int)$relationship_guid; $inverse_relationship = (bool)$inverse_relationship; $type = sanitise_string($type); - $subtype = get_subtype_id($subtype); + $subtype = get_subtype_id($type, $subtype); $owner_guid = (int)$owner_guid; $order_by = sanitise_string($order_by); $limit = (int)$limit; diff --git a/engine/schema/mysql.sql b/engine/schema/mysql.sql index 1b12bfd72..f087cde93 100644 --- a/engine/schema/mysql.sql +++ b/engine/schema/mysql.sql @@ -34,10 +34,14 @@ CREATE TABLE `prefix_entities` ( CREATE TABLE `prefix_entity_subtypes` (
`id` int(11) NOT NULL auto_increment,
+ `type` enum ('object', 'user', 'collection', 'site') NOT NULL,
`subtype` varchar(50) NOT NULL,
+ class varchar(50) NOT NULL default '',
+
PRIMARY KEY (`id`),
- UNIQUE KEY (`subtype`)
+ UNIQUE KEY (`class`),
+ UNIQUE KEY (`type`, `subtype`)
) ENGINE=MyISAM;
-- Describe relationships between entities, can describe friendships but also site membership, depending on context
|