aboutsummaryrefslogtreecommitdiff
path: root/services/export/handler.php
blob: d198149dae190d84311c241bf753936aa0a2180a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?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',elgg_view_title($title) . $body));
?>