<?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
 * @author Curverider Ltd
 * @link http://elgg.org/
 */

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) {
		throw new InvalidParameterException(sprintf(elgg_echo('InvalidParameterException:GUIDNotFound'), $guid));
	}

	$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) {
		throw new InvalidParameterException(sprintf(elgg_echo('InvalidParameterException:GUIDNotFound'), $guid));
	}

	$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) {
				throw new InvalidParameterException(sprintf(elgg_echo('InvalidParameterException:IdNotExistForGUID'), $id_or_name, $guid));
			}

			$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 = trigger_plugin_hook('volatile', 'metadata', array('guid' => $guid, 'varname' => $id_or_name));
			break;

		default :
			throw new InvalidParameterException(sprintf(elgg_echo('InvalidParameterException:CanNotExportType'), $type));
	}

	// 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'));
}

page_draw($title, elgg_view_layout('one_column_with_sidebar', elgg_view_title($title) . $body));