diff options
| -rw-r--r-- | engine/lib/entities.php | 57 | ||||
| -rw-r--r-- | engine/tests/objects/entities.php | 33 | 
2 files changed, 64 insertions, 26 deletions
| diff --git a/engine/lib/entities.php b/engine/lib/entities.php index daced6740..48c2e72b8 100644 --- a/engine/lib/entities.php +++ b/engine/lib/entities.php @@ -1378,34 +1378,27 @@ function disable_entity($guid, $reason = "", $recursive = true) {  				}  				if ($recursive) { -					// Temporary token overriding access controls -					// @todo Do this better. -					static $__RECURSIVE_DELETE_TOKEN; -					// Make it slightly harder to guess -					$__RECURSIVE_DELETE_TOKEN = md5(elgg_get_logged_in_user_guid()); - -					$sub_entities = get_data("SELECT * from {$CONFIG->dbprefix}entities -						WHERE container_guid=$guid -						or owner_guid=$guid -						or site_guid=$guid", 'entity_row_to_elggstar'); +					$sub_entities = get_data("SELECT * FROM {$CONFIG->dbprefix}entities +						WHERE ( +						container_guid = $guid +						OR owner_guid = $guid +						OR site_guid = $guid +						) AND enabled='yes'", 'entity_row_to_elggstar');  					if ($sub_entities) {  						foreach ($sub_entities as $e) { +							add_entity_relationship($e->guid, 'disabled_with', $entity->guid);  							$e->disable($reason);  						}  					} - -					$__RECURSIVE_DELETE_TOKEN = null;  				}  				$entity->disableMetadata();  				$entity->disableAnnotations(); -				// relationships can't be disabled. hope they join to the entities table. -				//$entity->disableRelationships();  				$res = update_data("UPDATE {$CONFIG->dbprefix}entities -					set enabled='no' -					where guid={$guid}"); +					SET enabled = 'no' +					WHERE guid = $guid");  				return $res;  			} @@ -1420,40 +1413,51 @@ function disable_entity($guid, $reason = "", $recursive = true) {   * @warning In order to enable an entity using ElggEntity::enable(),   * you must first use {@link access_show_hidden_entities()}.   * - * @param int $guid GUID of entity to enable + * @param int  $guid      GUID of entity to enable + * @param bool $recursive Recursively enable all entities disabled with the entity?   *   * @return bool   */ -function enable_entity($guid) { +function enable_entity($guid, $recursive = true) {  	global $CONFIG;  	$guid = (int)$guid;  	// Override access only visible entities -	$access_status = access_get_show_hidden_status(); +	$old_access_status = access_get_show_hidden_status();  	access_show_hidden_entities(true); +	$result = false;  	if ($entity = get_entity($guid)) {  		if (elgg_trigger_event('enable', $entity->type, $entity)) {  			if ($entity->canEdit()) { -				access_show_hidden_entities($access_status); -  				$result = update_data("UPDATE {$CONFIG->dbprefix}entities -					set enabled='yes' -					where guid={$guid}"); +					SET enabled = 'yes' +					WHERE guid = $guid");  				$entity->deleteMetadata('disable_reason');  				$entity->enableMetadata();  				$entity->enableAnnotations(); -				return $result; +				if ($recursive) { +					$disabled_with_it = elgg_get_entities_from_relationship(array( +						'relationship' => 'disabled_with', +						'relationship_guid' => $entity->guid, +						'inverse_relationship' => true, +					)); + +					foreach ($disabled_with_it as $e) { +						$e->enable(); +						remove_entity_relationship($e->guid, 'disabled_with', $entity->guid); +					} +				}  			}  		}  	} -	access_show_hidden_entities($access_status); -	return false; +	access_show_hidden_entities($old_access_status); +	return $result;  }  /** @@ -2318,3 +2322,4 @@ elgg_register_plugin_hook_handler('volatile', 'metadata', 'volatile_data_export_  /** Register init system event **/  elgg_register_event_handler('init', 'system', 'entities_init'); + diff --git a/engine/tests/objects/entities.php b/engine/tests/objects/entities.php index 1772f7c1a..a4dc7946c 100644 --- a/engine/tests/objects/entities.php +++ b/engine/tests/objects/entities.php @@ -226,6 +226,39 @@ class ElggCoreEntityTest extends ElggCoreUnitTest {  		$this->assertTrue($this->entity->delete());  	} +	public function testElggEntityRecursiveDisableAndEnable() { +		global $CONFIG; + +		$this->save_entity(); +		$obj1 = new ElggObject(); +		$obj1->container_guid = $this->entity->getGUID(); +		$obj1->save(); +		$obj2 = new ElggObject(); +		$obj2->container_guid = $this->entity->getGUID(); +		$obj2->save(); + +		// disable $obj2 before disabling the container +		$this->assertTrue($obj2->disable()); + +		// disable entities container by $this->entity +		$this->assertTrue($this->entity->disable()); +		$entity = get_data_row("SELECT * FROM {$CONFIG->dbprefix}entities WHERE guid = '{$obj1->guid}'"); +		$this->assertIdentical($entity->enabled, 'no'); + +		// enable entities that were disabled with the container (but not $obj2) +		$this->assertTrue($this->entity->enable()); +		$entity = get_data_row("SELECT * FROM {$CONFIG->dbprefix}entities WHERE guid = '{$obj1->guid}'"); +		$this->assertIdentical($entity->enabled, 'yes'); +		$entity = get_data_row("SELECT * FROM {$CONFIG->dbprefix}entities WHERE guid = '{$obj2->guid}'"); +		$this->assertIdentical($entity->enabled, 'no'); + +		// cleanup +		$this->assertTrue($obj2->enable()); +		$this->assertTrue($obj2->delete()); +		$this->assertTrue($obj1->delete()); +		$this->assertTrue($this->entity->delete()); +	} +  	public function testElggEntityMetadata() {  		// let's delete a non-existent metadata  		$this->assertFalse($this->entity->deleteMetadata('important')); | 
