aboutsummaryrefslogtreecommitdiff
path: root/www/functions/notused/func_download.php
blob: 26b25b1e896d6096845f6c49e27f26fc15bea053 (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

/*
	Expected state: tested, should work.
*/

function check_if_file($db, $name, $folder_path){

	$owner = user_id($db, $name);

	$file_id = select_file_id($db, $owner, $folder_path);

	if($file_id){
		$check_if_file_db = $db->query("SELECT folder FROM files WHERE id=".$file_id.";");
		$check_if_file_ar = $check_if_file_db->fetchArray(SQLITE3_NUM);

		if($check_if_file_ar[0] == "FILE"){
			return true;
		} else {
			return false;
		}
	} else {
		//$content = get_path_to_empty_folder($db, $name, $folder_path);
		//print_empty_folder($content);
		//get_404("/", "Protected file");
		return false;
	}
}

function start_file_download($user, $path){

	$db = $GLOBALS["db"];

	$owner = user_id($db, $user);

	$file_id = select_file_id($db, $owner, $path);

	$file_db = $db->query("SELECT owner, share FROM files WHERE id=" . $file_id . ";");
	$file_ar = $file_db->fetchArray(SQLITE3_NUM);
	$file_owner = $file_ar[0];
	$share = $file_ar[1];

	if($_SESSION["login"] && ($_SESSION["userid"] == $file_owner)){
		if(download_file($db, $file_id)){
			return true;
		} else {
			return false;
		}
	} else {
		if($share != "PUBLIC"){
			return false;
		}

		if(download_file($db, $file_id)){
			return true;
		} else {
			return false;
		}
	}
}

function check_file_hash($db, $file_id, $download_hash){
	if(preg_match("/[^0-9]/", $file_id)){
		return DOWNLOAD_FALSE_ID;
	}

	$check_hash_db = $db->query("SELECT owner, folder, share, download_link FROM files WHERE id=" . SQLite3::escapeString($file_id).";");
	$check_hash_ar = $check_hash_db->fetchArray(SQLITE3_NUM);

	if($check_hash_ar[1] != "FILE"){
		return DOWNLOAD_NOT_FILE;
	}

	if($check_hash_ar[2] != "PUBLIC"){
		if($_SESSION["userid"] != $check_hash_ar[0]){
			if($check_hash_ar[3] != $download_hash){
				return DOWNLOAD_PRIVATE_FILE;
			}
		}
	}

	if(!download_file($db, $file_id)){
		return false;
	} else {
		return true;
	}

}

function download_file($db, $file_id){

	$file_db = $db->query("SELECT name, mime, size, hash FROM files WHERE id=". SQLite3::escapeString($file_id).";");
	$file_ar = $file_db->fetchArray(SQLITE3_NUM);

	$file_name = $file_ar[0];
	$file_mime = $file_ar[1];
	$file_size = $file_ar[2];
	$file_hash = $file_ar[3];

	$uploaddir = "../files/";
	$gzip_file = $uploaddir . $file_hash . ".gz";

//TODO: buffer output, print if reading == true

	header("Content-Type: ".$file_mime);

	if(!preg_match("/^image\/.+/", $file_mime)){
		header("Content-Disposition: attachment; filename=\"".$file_name."\"");
	} else {
		header("filename=".$file_name."");
	}
	header("Content-Length: ".$file_size);
	set_time_limit(0);
	$uncompressed_file = readgzfile($gzip_file);

	if($uncompressed_file){
		return true;
	} else {
		return false;
	}


}