diff options
Diffstat (limited to 'services/export/handler.php')
| -rw-r--r-- | services/export/handler.php | 117 | 
1 files changed, 0 insertions, 117 deletions
diff --git a/services/export/handler.php b/services/export/handler.php deleted file mode 100644 index 9f9f9a86a..000000000 --- a/services/export/handler.php +++ /dev/null @@ -1,117 +0,0 @@ -<?php -/** - * Open Document Definition Handler. - * This file acts as the endpoint for ODD UUID url requests, exporting the requested data as an - * OpenDD XML file. - * - * @package Elgg - * @subpackage Core - */ - -require_once("../../engine/start.php"); - -// Get input values, these will be mapped via modrewrite -$guid = get_input("guid"); // guid of the entity - -// For attributes eg http://example.com/odd/73/attr/owner_uuid/ -// or http://example.com/odd/73/metadata/86/ -$type = get_input("type"); // attr, metadata, annotation, rekationship -$id_or_name = get_input("idname"); // Either a number or the key name (if attribute) - -$body = ""; -$title = ""; - -// Only export the GUID -if (($guid != "") && ($type == "") && ($id_or_name == "")) { -	$entity = get_entity($guid); - -	if (!$entity) { -		$query = elgg_echo('InvalidParameterException:GUIDNotFound', array($guid)); -		throw new InvalidParameterException($query); -	} - -	$title = "GUID:$guid"; -	$body = elgg_view("export/entity", array("entity" => $entity, "uuid" => guid_to_uuid($guid))); - -	// Export an individual attribute -} else if (($guid != "") && ($type != "") && ($id_or_name != "")) { -	// Get a uuid -	$entity = get_entity($guid); -	if (!$entity) { -		$msg = elgg_echo('InvalidParameterException:GUIDNotFound', array($guid)); -		throw new InvalidParameterException($msg); -	} - -	$uuid = guid_to_uuid($entity->getGUID()) . "$type/$id_or_name/"; - -	switch ($type) { -		case 'attr' : // @todo: Do this better? - This is a bit of a hack... -			$v = $entity->get($id_or_name); -			if (!$v) { -				$msg = elgg_echo('InvalidParameterException:IdNotExistForGUID', array($id_or_name, $guid)); -				throw new InvalidParameterException($msg); -			} - -			$m = new ElggMetadata(); - -			$m->value = $v; -			$m->name = $id_or_name; -			$m->entity_guid = $guid; -			$m->time_created = $entity->time_created; -			$m->time_updated = $entity->time_updated; -			$m->owner_guid = $entity->owner_guid; -			$m->id = $id_or_name; -			$m->type = "attr"; -			break; -		case 'metadata' : -			$m = get_metadata($id_or_name); -			break; -		case 'annotation' : -			$m = get_annotation($id_or_name); -			break; -		case 'relationship' : -			$r = get_relationship($id_or_name); -			break; -		case 'volatile' : -			$m = elgg_trigger_plugin_hook('volatile', 'metadata', -				array('guid' => $guid, 'varname' => $id_or_name)); -			break; - -		default : -			$msg = elgg_echo('InvalidParameterException:CanNotExportType', array($type)); -			throw new InvalidParameterException($msg); -	} - -	// Render metadata or relationship -	if ((!$m) && (!$r)) { -		throw new InvalidParameterException(elgg_echo('InvalidParameterException:NoDataFound')); -	} - -	// Exporting metadata? -	if ($m) { -		if ($m->entity_guid != $entity->guid) { -			throw new InvalidParameterException(elgg_echo('InvalidParameterException:DoesNotBelong')); -		} - -		$title = "$type:$id_or_name"; -		$body = elgg_view("export/metadata", array("metadata" => $m, "uuid" => $uuid)); -	} - -	// Exporting relationship -	if ($r) { -		if (($r->guid_one != $entity->guid) && ($r->guid_two != $entity->guid)) { -			throw new InvalidParameterException(elgg_echo('InvalidParameterException:DoesNotBelongOrRefer')); -		} - -		$title = "$type:$id_or_name"; -		$body = elgg_view("export/relationship", array("relationship" => $r, "uuid" => $uuid)); -	} - -	// Something went wrong -} else { -	throw new InvalidParameterException(elgg_echo('InvalidParameterException:MissingParameter')); -} - -$content = elgg_view_title($title) . $body; -$body = elgg_view_layout('one_column_with_sidebar', array('content' => $content)); -echo elgg_view_page($title, $body);
\ No newline at end of file  | 
