aboutsummaryrefslogtreecommitdiff
path: root/actions/delete.php
blob: e142e96606636e2394387eb7cb8f08055325f47c (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
<?php

	/**
	 * Tidypics Delete Action
	 * 
	 */

	//if not logged in, see world pictures instead
	if (!isloggedin()) forward('pg/photos/world');

	$guid = (int) get_input('file');
	$forward_url	= 'pg/photos/world'; //forward to world pictures if there is an unknown error

	if ($photoObject = get_entity($guid)) {
		if ($photoObject->canEdit()) {
			$subtype = $photoObject->getSubtype();
			$container = get_entity($photoObject->container_guid);
			
			if ($subtype!='image' && $subtype!='album') forward(get_input('forward_url', $_SERVER['HTTP_REFERER'])); //back off if not an album or image
			
			if ($subtype == 'image') { //deleting an image
				$forward_url = $container->getURL(); //forward back to album after deleting pictures
				$images = array($photoObject);
			} else { //deleting an album
				$forward_url = 'pg/photos/owned/' . $container->username;
				$images = get_entities("object","image", $guid, '', 999); //get all the images from this album, or the image requested
			} //end of subtype comparison

			//loop through all images and delete them
			foreach($images as $im) {
				$thumbnail = $im->thumbnail;
				$smallthumb = $im->smallthumb;
				$largethumb = $im->largethumb;

				if ($thumbnail) { //delete standard thumbnail image
					$delfile = new ElggFile();
					$delfile->owner_guid = $im->getOwner();
					$delfile->setFilename($thumbnail);
					$delfile->delete();
				}
				if ($smallthumb) { //delete small thumbnail image
					$delfile = new ElggFile();
					$delfile->owner_guid = $im->getOwner();
					$delfile->setFilename($smallthumb);
					$delfile->delete();
				}
				if ($largethumb) { //delete large thumbnail image
					$delfile = new ElggFile();
					$delfile->owner_guid = $im->getOwner();
					$delfile->setFilename($largethumb);
					$delfile->delete();
				}
				if ($im) { //delete actual image file
					$delfile = new ElggFile($im->getGUID());
					$delfile->owner_guid = $im->getOwner();
					//$delfile->setFilename($im->originalfilename);
					if (!$delfile->delete()) {
						if ($subtype=='image') register_error(elgg_echo("file:deletefailed")); //unable to delete object
					} else {
						if ($subtype=='image') system_message(elgg_echo("file:deleted")); //successfully deleted object
					}
				} //end delete actual image file
			} //end looping through each image to delete it
			
			//now that all images have been deleted, delete the album
			if ($subtype=='album') {
				//delete the album's directory manually; first create a temp file to get the directory path
				$tmpfile = new ElggFile();
				$tmpfile->setFilename('image/' . $guid . '/._tmp_del_tidypics_album_');
				$tmpfile->subtype = 'image';
				$tmpfile->container_guid = $guid;
				$tmpfile->open("write");
				$tmpfile->write('');
				$tmpfile->close();
				$tmpfile->save();
				$albumdir = eregi_replace('/._tmp_del_tidypics_album_', '', $tmpfile->getFilenameOnFilestore());
				$tmpfile->delete();
				if (is_dir($albumdir))
					rmdir($albumdir);
				
				//delete object from database
				if (!$photoObject->delete()) {
					register_error(elgg_echo("file:deletefailed")); //unable to delete object
				} else {
					system_message(elgg_echo("file:deleted")); //successfully deleted object
				}
			} //end of delete album


		} else { //user does not have permissions to delete this image or album
			$container = $_SESSION['user'];
			register_error(elgg_echo("file:deletefailed"));
		} //end of canEdit() comparison

	} else { // unable to get Elgg entity
		register_error(elgg_echo("file:deletefailed"));			
	} //end of get_entitty()
		
	forward($forward_url);

?>